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interference to radio or television reception, which can be determined by turning the equipm^t off 
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• Reorient or relocate the receiving antenna 

• Increase the separation between the equipment and receiva* 

• Connect the equipnent into an outlet on a circuit different from that to which the 
receiver is connected 

• Consult your supplier, or an experienced radio or television technician for help 


Modiflcations 

This equipment contains no user-serviceable parts. You are advised that unauthorized changes or 
modifications to the equipment could cause it to exceed Class B limits and may void the authority 
granted by the FCC to operate the equipment 

Shielded Cables 

Connections between the SPARCbook and any connected peripherals must be made using shielded 
cables to maintain compliance with FCC radio frequency emission limits. 
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This equipment complies with Part 68 of the FCC rules. On the underside of this equipment is a 
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If this equipment causes harm to the tele^^one network, the telephone company will notify you in 
advance that temporary discontinuance of service may be required. If advance notice is not 
practical, the telephone company will nodfy the customer as soon as possible. Also, you will be 
advised of your right to file a complaint with the FCC if you believe it is necessary. 

The telei^one company may make changes in its facilities, equipment, operations or procedures 
that could affect the operation of the equipment If this happois, the telej^one company will 
provide advance notice in order for you to make the necessary modifications in order to maintain 
uninterrupted service. 

If trouble is experienced with this equipment please contactTadpoleTechnology Inc, 8310 Capital 
of Texas Highway North, Austin, Texas 78731 Tel: (512) 338 4221 for repair and/or warranty 
information. If the trouble is causing harm to the telq)hone network, the telephone company may 
request you remove the equipment from the network until the problem is resolved. 

The following repairs can be done by the customer: None 

This equipnent cannot be used on telephone company-provided coin service. Connection to Party 
Line Service is subject to state tariffs. 
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INTRODUCTION 
TO THE 

SPARCbook TECHNICAL REFERENCE MANUAL 


The SPARCbook Technical Reference Manual is published as a supplement to the SPARCbook User's 
Guide to provide additional technical information. This document describes the hardware (qieration of 
the SPARCbook notebook computer and also provides details about the resident operating system 
supplied with each unit. 
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MANUAL STRUCTURE 


The SPARCbook Technical Reference Manual is structured as follows: 

• Technical Overview 

Ch^t^ 1 discusses the principle features of the SPARCbook and 
introduces the reader to the main hardware devices that provide control 
over the SPARCbook's opmtions. 

• Architecture Overview 

Chi^ter 2 describes the internal architecture of the SPARCbook, showing 
how the major devices are connected together. 

• Detailed Device Descriptions 

Chaptm 3-11 discuss in some dq)th the implementation of the major 
hardware devices in the SPARCbodc. 

• Schematics Description 

Chapter 12 provides a description of the schematic diagrams and discusses 
the theory of opoation. 


INTENDED AUDIENCE 


The SPARCbook Technical Reference Manual is aimed at the hardware engineer wishing to carry out 
service or repairs, and at the software engineer wishing to implement hardware drivers. 

It is assumed that the reado^ is familiar with the opoation of SPARCbook, as detailed in the 
SPARCbook User Guide, and has a basic understanding of computer hardware. 
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CONVENTIONS USED IN THIS DOCUMENT _ 

The reader is advised to note the following conventions employed in the SPARCbook Technical 
Reference Manual. 

Logic states 

The t^ms Clear or low indicate that the signal being discussed is at the logic level 'O', 

The terms Set or high indicate that the signal being discussed is at the logic level '1'. 

The tom Asserted indicates that a signal is in its true or active state regardless of 
wheth^that state is high or low. 

The tmn Negated indicates that a signal is in its false or inactive state regardless of 
whetho-that state is high or low. 

Data Length Definitions 

A Hazard is taken to contain 16 bits. 

A word is taken to contain 32 bits. 

A doubleword is taken to contain 64 bits 



CHAPTER ONE 
OVERVIEW 


The SPARCbook provides in a compact notebodt ftHinat many of the advanced features and high 
performance normally associated with desktop woikstations. Lx)w power consumption and compact¬ 
ness have been achieved by the use of highly integrated components without compromising either the 
functionality or performance of the SPARCbotdc. 

The SPARCbook is housed in a magnesium alloy case measuring 11.8" x 8.5” x 1.9", and weighs 
6.81bs, including battmes and peripherals. 

The SPARCbook’s standard features include a 640 x 480 pixel color or monochrome liquid crystal 
display, an 82-key keyboard, a 3.5" floj^y disk drive, an IDE hard disk drive, and Modem, Ethernet, 
Centronics and serial interfaces. A second hard disk drive is available as an option, when it is fitted in 
substitution for the floppy disk drive. 

All of the major integrated circuit components are carried on a single printed circuit board, using the 
latest surface mount technology and avoiding the need for space consuming and power hungry 
expansion cards. The use of components with low power demand and the SPARCbodc’s advanced 
power management facilities allow the SPARCbook to be used continuously for 2.S hours or more 
when powered from the battery. 



CENTRAL PROCESSOR 


Processing power in the SPARCbook is provided by the Cypress CY7C6(X) implementation of the 
Scalable Processor Architecture (SPARC) RISC microprocessor. The Cypress CY7C600 is a chip set 
which comprises the following: 

• Integer Unit (lU) 

• Cache Controller and Memory Management Unit (CMU) 

• Optional Floating Point Unit (FPU) 

• 64Kbytes zero wait state Cache 

Hie lU is the basic processing engine which executes all of the instruction set except for floating point 
instructions which are performed by the FPU when it is fitted. The CMU provides memory manage¬ 
ment and address translation facilities between the SPARC virtual bus and the main system bus. Two 
CY7C157 SRAM devices provide 64Kbytes of fast cache memory resident on the SPARC virtual bus. 

The SPARC CPU is a RISC (reduced instruction set compute) based process^. It uses a simplified 
range of commands to carry out operations, enabling most instructions to execute within a single clock 
cycle. 

Conventional processors tend to use large and complex instruction sets, taking several clock cycles to 
perform each instruction. Many of the instructions available to this type of processor are rarely if ever 
used, a fact that has led to the develofment of RISC processor concepts. 

The already high p^ormance of the SPARC CPU is further enhanced by the ability of FPU to 
execute instructions simultaneously with the lU, and by the provision of cache memory. The Cache 
memory is specialized area of fast (zero wait state) memory which allows many instructions and 
operands to be fetched locally by the CPU without it having to access the comparatively slow main 
memory. 


MAIN MEMORY 


The SPARCbook is built using either 4Mbit or 16Mbit DRAM devices to provide 8 or 32Mbyles of 
DRAM. The main memory provides a 64-bit wide bus interface designed specifically to support burst 
cycles by the CPU. 




The memory management unit maintains entries in cache memory called cache lines, each one a 256 
bits wide copy of a similar sized area of main memory. When the lU requires data that is not present 
in the cache, the MMU copies the new data from main memory to cache memory using burst cycles of 
four 64-bit reads (see Chapter Three). 

Using burst transfers, the memory interface is ctq>able of a transfer rate of 72Mbyte/s. While using 
random access a transfer rate of 40Mbyte/s is achieved. Both rates are at a 25MHz processor clock 
speed. 

The main memory also features software selectable parity protection. 


DISPLAY 


The SPARCbook is equipped with a 640 x 480 pixel color or monochrome liquid crystal flat panel 
display. Both types are si(te-lit by a cold fluorescent lamp, which can be controlled to vary the screen 
brightness. Reducing the brightness of the sidelight reduces the power consumption, prolonging 
battery life. 

The display is controlled by a GD6410 VGA compatible display controller made by Cirrus Logic. 
This inovides control for a monochrome LCD display and for an external color CRT display. Both 
displays may be used simultaneously. Advanced grey scale control by the GD6410 provides quality 
grey scale rendering of color images for clear display on the LCD. 

In the color SPARCbook, a GD6340 color LCD controller provides the additional control required for 
the color LCD display. The color model is able to display 16 colors simultaneously from a palette of 
262144. 

The SPARCbook supports three display modes: 

• Mode 1 - Inbuilt LCD only 

• Mode 2 - Simultaneous LCD and standard VGA 640 x 480 Color monitor 

• Mode 3 - Extended VGA 800 x 600 external high resolution only 

Both color and monochrome models of the SPARCbook are able to display an image in 16 colors on 
the external monitor. They are both able to display the same image simultaneously on the LCD and 
external CRT when in mode 2. 

Mode 3 allows the SPARCbook to display an image on an extmial high resolution monitor, but turns 
the inbuilt LCD screen off. This mode requires the use of a multisync monitor. 
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UNIVERSAL PERIPHERAL CONTROLLER 


One of the highly integrated devices used in the SPARCbook to achieve its compact size is the 
82C710 Univers^ Peripheral Controller (UPC) manufactured by Chips and Technologies Inc. This 
single device provides the following: 

• Hard Disk Control 

• Floppy Disk Control 

• Centronics Interfacing 

• External Mouse/Keyboard Interfacing 

• RS232 Serial Interfacing 

Floppy Disk Control 

The urc provides control for one ot two IDE (Integrated Drive Electronics) PC/AT compatible hard 
disk drives. It provides a complete electronic interface, and control of a 16-bit data buffer. 

Floppy Disk Control 

Single hard disk versions of the SPARCbook contain a 3.5" floppy disk drive. The UPC provides an 
NEC765 compatible command set for control of the drive, and the SPARCbook's operating system 
allows 720Kbyte and 1.4Mbyte SUN and IX)S format disks to be read and written. 

Centronics Interface 

The UPC provides control and data buffering for the parallel interface which appears on the rear panel 
of the SPARCbook. This interface supports connection to a printer with a Centronics interface. 

External Mouse/Keyboard Interface 

The UPC provides data buffering and control over a serial interface. This interface supports the 
connection of an external mouse or keyboard and appears via a 6-way mini DIN socket on the rear 
panel. This int^ace operates with TTL signal levels and does not allow the connection of RS232 
devices. 

RS232 Serial Interface 

In addition to the TTL serial interface, the UPC provides data buffering and control over an RS232 
serial interface. 



MICROCONTROLLER SUBSYSTEM 


An 87C51 microcontroller provides control over the in-built keyboard, the bit I/O interface and the 
power management functions. 

The bit VO interface enables aspects of the SPARCbook’s functionality to be controlled in software 
using keyboard commands. The microcontroller int^rets certain special characters from the key¬ 
board as being commands, and carries out system configuration changes accordingly. This includes 
display screen brightness and contrast. 

The bit I/O interface also controls the LEDs next to the display in order to convey machine status 
information to the user. 

The power management function maintains a constant check on the condition of the supply voltages, 
and provides early warning when the battoy requires recharging. Recharging is carried an in-built 
power suiq)ly unit and battery charger when the SPARCbook is connected to an external electricity 
supply. 

The microcontroller also provides control over the Mousekey. 


ETHERNET INTERFACE 


The SPARCbook is equipped with an IEEE802.3 compliant Ethernet intfflface controlled by a 86960 
Network Interface Controller with Encoder (NICE) fi'om Fujitsu. This provides complete control over 
the network interface. 

The NICE has direct control over a 64Kbyte area of SRAM in which it maintai n s receive and transmit 
buffers. The host is able write data into the transmit buffer and read data of the receive buffer via 
port in the NICE'S address space. The NICE is able to carry out network operations with minimal 
demand on the CPU, and an integral driver and receiver interfaces directly to the 15-way D-type 
socket at the rear of the unit 



MODEM 


The SPARCbook’s modem interface is implemented with chipset comprising a Sierra SCI 1075 
Modem Access Controller (MAC) and SCI 1054. The SCI 1075 provides a direct interface between 
the host system and SCI 1054 modem; it incorporates an Intel 80% equivalent processor core, sup¬ 
porting an AT command set; it contains a built-in 16C450 equivalent UART; and it contains 16Kbytes 
of on-chip ROM and 320bytes of RAM. 

The SCI 1054 is a complete 2400bps (bits per second) modem IC which, whrai combined with the 
SCI 1075, provides Sendfax capability up to %00bps. 

The modem intaftK;e can be controlled completely using Hayes compatible commands written to the 
UART section of the MAC. Commands are sent to the int^ace using character strings, and these are 
interpreted by the MAC’S in-built processor core and acted on appropriately. 

Command characters and data for transmission onto the telephone line are written into the UART’s 
transmit buffer. Data received from the telephone line and status information firom the MAC can be 
read from the UART’s receive buffer. 


REAL TIME CLOCK AND EPROM 


Many of the background operations of the SPARCbook, such as syst^ startup and battery condition 
monitoring, are controlled by the Tadpole resident firmware monitor. This is a body of software (most 
often referred to as firmware) that is permanently stored in an EPROM and is not erased when the 
machine is without power. 

A 48T02 provides a battery backed real time clock and non-volatile RAM. This iwovides time of day 
clock and calendar functions and a 2Kbyte area of RAM which retains data when the board is without 
power. 

A 1Mbit serially accessed EEPROM is used by the resident firmware to store the SPARCbook’s 
Ethernet address and manufacturing information. The EEPROM is accessible via the microcontroller. 
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SPARCbook TECHNICAL SPECIFICATION _ 

• Processor and Memory 

Processor 25MHz CY601 Integer Unit 
Cache Contioller/MMU 25MHz CY604 CMU 

Cache 64Kbyte direct m^ped virtual cache 
FPU (optional) 25MHz CY602 Floating Point Unit 
DRAM (standard) SMbytes with byte parity 
DRAM (-E models) 32Mbytes with byte parity 

• Components 

EPROM 128Kbytes - 1Mbyte One 8-bit 32-pin JEDEC socket 

SERIAL UPC One asynchronous RS232p(xt 

TxD, RxD, CTS, RTS, DCD, 
DTR,DSR,RING 

MISC MK48T02 RTC/2Kbyte DRAM with battery backup 

NMC93C46 1Kbit EEPROM 

NETWORK Fujitsu NICE ControUw IEEE802.3 interface with local buffer memory 

DISK 82C710 UPC Controller Two IDE disks suf^rted 

Floppy disk controller 

• I/O Interfaces 

Ethernet IEEE802.3 compliant 

15-pin D-type AUI interface with slidelock 
Centronics IBM PS/2 compatible int^ace 

36-pin miniature D-type with cable to 2S-pin 
D-type socket 

Mouse/Keyboard IBM PS/2 compatible (TTL) 

6-pin mini-DIN socket 

Modem 2400baud data and 9600baud SendFax 
FCC Part 68 compliant, 0.3 REN 
V.29, V.27ter, V.22bis, V.22, V.21 
Bell 212A, Bell 103 standards 
RJll jack socket 


• Peripherals 


• Display 


• Keyboard 


VGA 640x480 25.057MHz dot clock 

800x600 36.242MHz dot clock (external monitor) 
15-pin PS/2 compatible D-type connector 
Serial 110 to 38400baud 

9-pin mini-DIN connector 


Winchester disk 85Mbyte formatted IDE interface or 125Mbyte 
formatted IDE interface, dq)ending upon model 
One or two drives per system 
Maximum transfer rate 8Mbyt^s buffer to memory 
Maximum sustained transfer rate 1.8MbytB/s 
Floppy disk 720Kbyte/l .44Mbyte formatted 3.5" floppy disk 
drive 

Fitted in single Winchester disk models 


Monochrome 640x480 VGA paper-white display side-lit 
Displays 16 gray scales from 64 
Color (-C models) 64(k480 VGA color STN display side-lit 
Displays 16 colors from 256 

82-key notebook style with integral Mousdcey 
based upon Force Sensitive Resistor (FSR) tech¬ 
nology 


• LEDs 

External DC supply connected 
Hard disk active 
User controlled indicator 
Battery low/exhausted indicator 


• Case and Emissions 


Magnesium alloy AZ91 castings 
SPARCbook is certified to FCC Part 15 Class B 
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Power Supply 


Internal 

External 


Physical 

Dimensions 
Weight (with battery) 
(without battery) 


Environmental 

Temperature (operational) 
(storage) 
Vibration (operational) 
(storage) 
Shock (operating) 
(storage) 
Humidity (operating) 

Operating System 

SunSoft Solaris 1.01 
Comprising 


Switched mode PSU with battery charge and 

charge detection 

facilities 

Universal input 110V-240V AC 
Output 18V 0-3.1A DC 


11.8" X 8.5" X 1.95" 

6.81b/7.01b (monochrome/color) 
5.21b/5.41b (monochrome/color) 


5-40 degrees Celsius 
-20 - 60 degrees Celsius 
5-lOOHz 0.25G 
5-lOOHz 1.2G 
4G 
50G 

8-80% relative humidity 


SPARCbook Version A 
SunOS 4.1.2 sun4m architecture 
OpenWindows V3 
SPARCbook utilities 

Meets SPARC Compliance Definition (SCD) 1.1 
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SPARCbook DETAILED ADDRESS MAP 

This section provides a detailed address map for the SPARCbodc. Please note the meanings of the 

following abbreviations used in the address map. All addresses are shown in hexadecimal. 


R/W: R = read, W = Write 




SIZE; b = byte, h= halfword (16-bits), w= word (32-bits), d = doubleword (64-bits) 


DRAM 

ADDRESS 

DEVICE or REGISTER 

R/W 

SIZE 

000000000 - 0007FFFFF 

DRAM (8Mbyte) 

R/W 

b/h/w/d 

000000000 - OOIFFFFFF 

DRAM (32Mbyte) 

R/W 

b/h/w/d 

Display Controller 

OOCOOOOOO - OOCCFFFFF 

CL-GD6410/CL-GD634Gt ^ 

CRTC Index MP b’- ^ ° 



00C0003B4 

R/W 

b 

00C0003B5 

CRTCDataMP 

R/W 

b 

00C00O3CO 

Attribute Controller Index 

R/W 

b 


Data 

W 

b 

00C0003C1 

Attribute Controller Data 

R 

b 

00C0003C2 

Misc Output 

W 

b 


Feature 

R 

b 

OOC0OO3C3 

Motherboard Sleep Address 

R/W 

b 

00C0003C4 

Sequencer 

R/W 

b 

00C0003C5 

Sequencer 

R/W 

b 

00C0003C6 

RAMDAC Pixel Mask 

R/W 

b 

00C0003C7 

RAMDAC Address - Read Mode 

W 

b 


RAMDAC Status Register 

R 

b 

00C0003C8 

RAMDAC Address - Write Mode 

W 

b 

00C0003C9 

RAMDAC Data 

R/W 

b 

00C0003CA 

Feature Control 

R 

b 

00C0003CC 

Misc Output 

R 

b 

00C0003CE 

Graphics Controller and Extensions Index 

R/W 

b 

00C0003CF 

Graphics Controller and Extensions Data 

R/W 

b 

00C0003D4 

CRTC Index 

R/W 

b 

00C0003D5 

CRTC Data 

R/W 

b 

00C0003DA 

Feature Control 

W 

b 


Display Status 

R 

b 

00C0046E8 

AT Adapter Sleep Address 

R/W 


Note t CL-GD6340 only present 

in color models. It contains RAMDAC registers shadow mapped 

over 

similar CL-GD6410 registers. 
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Ethernet Controller 


ADDRESS 

DEVICE or REGISTER 

R/W 

SIZE 

00C200000 - OOCFFFFF 

Fujitsu 86960 NICE 



00C200000 

Transmit Status 

R/W 

b 

00C200001 

Receive Status 

R/W 

b 

00C200002 

Transmit Interrupt Mask 

R/W 

b 

OOC200003 

Receive Interrupt Mask 

R/W 

b 

OOC200004 

Transmit Mode 

R/W 

b 

00C200005 

Receive Mode 

R/W 

b 

00C200006 

Control Register 1 

R/W 

b 

00C200O07 

Control Register 2 

R/W 

b 

00C2000O8 

Node ID (Register Bank 0) 

R/W 

b 


Mask Address (Register Bank 1) 

R/W 

b 


Buffer Mmory Port (Register Bank 2) 

R/W 

h 

00C200009 

Node ID (Register Bank 0) 

R/W 

b 


Mask Address (Register Bank 1) 

R/W 

b 

00C20000A 

Node ED (Register Bank 0) 

R/W 

b 


Mask Address (Register Bank 1) 

R/W 

b 


Transmit packet Control 1 (Register Bank 2) 

R/W 

b 

00C20000B 

Node ID (Register Bank 0) 

R/W 

b 


Mask Address (Register Bank 1) 

R/W 

b 


Transmit packet Control 2 (Register Bank 2) 

R/W 

b 

00C20000C 

Node ID (Register Bank 0) 

R/W 

b 


Mask Address (Register Bank 1) 

R/W 

b 


DMA Enable (Register Bank 2) 

R/W 

b 

00C20000D 

Node ID (Register Bank 0) 

R/W 

b 


Mask Address (Register Bank 1) 

R/W 

b 


DMA Burst Control (Register Bank 2) 

R/W 

b 

00C20000E 

TDR (LSB) (Register Bank 0) 

RAV 

b 


Mask Address (Register Bank 1) 

R/W 

b 


Receive Buffer Pointer (Register Bank 2) 

R/W 

b 

00C20000F 

TDR (MSB) (Register Bank 0) 

R/W 

b 


Mask Address (Register Bank 1) 

R/W 

b 

Note: Register Bank 0,1 and 2 

are selected using bits 2 and 3 of Control Register 2 
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Modem Interface 


ADDRESS 

DEVICE or REGISTER 

R/W 

SIZE 

OOC400000 - 00C4FFFFF 

Sierra SCI 1075 - UART Registers 



OOC400000 

Receive Buffer 

R 

b 


Transmit Buffer 

W 

b 


Divisor Latch (LSB)t 

R/W 

b 

00C400001 

Interrupt liable 

R/W 

b 


Divisor Latch (MSB) t 

R/W 

b 

00C400002 

Interrupt ID 

R 

b 

00C400003 

Line Control 

R/W 

b 

00C400004 

Modem Control 

R/W 

b 

00C400005 

Line Status 

R/W 

b 

00C400006 

Modem Status 

R/W 

b 

00C400007 

Scratch Pad 

R/W 

b 

Note: t The divisor latch can be accessed only when bit 7 of the Line Control Register is set 



Real Time Clock / SRAM 


OOC600000 - 00C7FFFFF 

MK48T02 



00C600000 

SRAM 

R/W 

b/h/w/d 

00C6007F8 

Calibration 

R/W 

b 

00C6007F9 

Seconds 

R/W 

b 

00C6007FA 

Minutes 

R/W 

b 

00C6007FB 

Hours 

R/W 

b 

00C6007FC 

Day 

R/W 

b 

00C6007FD 

Date 

R/W 

b 

00C6007FE 

Month 

R/W 

b 

00C6007FF 

Year 

R/W 

b 

16-Bit HO Region - Hard Disk Data Interface 


00C800000 - OOCBFFFFF 

00C8001F0 IDE - Hard Disk Data Interface 


R/W h 




8-Bit HO Region - UPC Associated Interfaces 

ADDRESS 

DEVICE or REGISTER 

R/W 

SIZE 

OOCCOOOOO - OOCEFFFFF 

82C710 Universal Perpheral Controller 



OOCCOOIFI 

IDE - Error Register 

R 

b 

OOCC0O1F2 

IDE - Sector Count 

R/W 

b 

00CC001F3 

IDE - Sector Number 

R/W 

b 

00CC001F4 

IDE - Cylinder Low 

R/W 

b 

OOCCOOIFS 

IDE - Cylinder High 

R/W 

b 

00CC001F6 

IDE - Drive/Head Register 

R/W 

b 

OOCC0O1F7 

IDE - Status Register 

R 

b 


IDE - Command Register 

W 

b 

00CC003F6 

IDE - Alternate Status 

R 

b 


IDE - Fixed Disk Register 

W 

b 

00CC00310 

Mouse Port - Data Register 

R/W 

b 

00CC00311 

Mouse Port - Status/Control Register 

R/W 

b 

00CC00330 

Parallel Port - Data Register 

R/W 

b 

00CC00331 

Parallel Port - Status Register 

R 

b 

00CC00332 

Parallel Port - Command Register 

w 

b 

00CC00390 

UPC Configuration Index 

w 

b 

00CC00391 

UPC Configuration data 

R/W 

b 

00CC003F2 

Floppy I/F - Digital O/P Register 

w 

b 

00CC003F4 

Floppy I/F - Main Satus Register 

R 

b 

00CC003F5 

Floppy I/F - Data Register 

R/W 

b 

00CC003F7 

Floppy I/F - Data Rate 

W 

b 


Floppy I/F - Digital Input Register 

R 

b 

00CC003F8 

UART - Receive Buffe 

R 

b 


UART - Transmit Buffer 

W 

b 


UART - Baud Rate Divisor (LSB)t 

R/W 

b 

00CC003F9 

UART - Interrupt Enable Register 

R/W 

b 


UART - Baud Rate Divisor (MSB)t 

R/W 

b 

00CC003FA 

UART - Interrupt Flag Register 

R/W 

b 

00CC003FB 

UART - Byte Format Register 

R/W 

b 

00CC003FC 

UART - Modem Control Register 

R/W 

b 

00CC003FD 

UART - Line Status Register 

R/W 

b 

00CC003FE 

UART - Modem Status Register 

R/W 

b 

00CC003FF 

UART - Scratch Pad 

R/W 

b 

Note: t The Baud Rate Divisor Registers can only be accessed when bit 7 of the Byte Control Register is set. 
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MPIASIC 


ADDRESS 

OODOOOOO-OODFFFFFF 
OODOOOOOO 
OODOOOOlO 
0OD0OOO18 
00D000020 
00D000028 
00D000030 
OOD00OO38 
00D000050 
00D000058 
00D000060 
00D000068 
00D000070 
00D000088 
00D000090 
00D000098 
OODOOOOAO 
00D0000A8 
OODOOOOB8 
OODOOOOCO 
OODOOOOC8 
OODOOOOF8 

RAV: R = read, W = Write 

SIZE: b = byte, h = halfword (16-bits), w = word (32-bits), d = doubleword (64-bits) p 

n 

f 


DEVICE or REGISTER 


Mbus to Pbus Interface Controller 

Mbus Error Status 

Set Count CTO 

Current Count CTO 

Control CTO 

Set Count CTl 

Current Count CTl 

Control CTl 

Interrupt Pending 

Interrupt Polarity 

Interrupt Enable 

Interrupt Acknowledge 

Serial Receive Port 

Serial Receive Status 

Serial Transmit Port 

Serial Transmit Data 

Reset 

Clock Control 
Power Down 
FIFO Start Address 
FIFO Control 
FIFO Data 
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CHAPTER TWO 
ARCHITECTURE 


I 

u 


One of the factors that contributes to the compactness of the SPARCbook is that at its heart is a single 
board of less than 12 square inches, the Base Board. This one board carries the processor module, 
provides 8 or 32Mbytes of memory and provides all of the control required for the display, keyboard, 
disks and interfaces. 

This section provides a brief description of the architecture of the SPARCbook. Figure 2-1 shows 


how the main components connect together. 
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Figure 2-1 SPARCbook Internal Architecture 
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BUS STRUCTURE 


It will be seen from Figure 2-1 that the SPARCbook is based on a dual bus architecture, with the 
SPARC CPU and DRAM connected to a fast 64-bit bus, called the Mbus, and the I/O devices con¬ 
nected to a 16-bit peripheral bus called the Pbus. 

The SPARC jn’ocessor is the only Mbus master device and is able to access aU locations in DRAM, 
and locations on the Pbus via the MPI. 

As described in the previous chapter, the SPARC CPU comprises the integer unit, floating point unit 
and the combined memory management unit and cache controller. Hiese communicate via a private 
address bus which remains local to the SPARC chipset This consists of a 32-bit address bus, an 8-bit 
address space identifier bus, and a 32-bit data bus. The lU uses logical (or virtual) addresses as labels 
to identify locations in its address space. The memory management unit translates the virtual ad¬ 
dresses used on this bus into physical addresses used on the M-bus. 


Mbus 


The Mbus is an address and data multiplexed bus, which means that some of the wires are used to 
carry both address information and data, though at different times. The time when address information 
is on the bus is the address phase, and the time when data is on the bus is the data phase. In a SPARC 
based environment, a bus cycle consists of an address phase followed by one data phase for single 
access cycle, (h* an address phase and four data phases for a burst cycle. 

The memory management unit produces a physical address on Mbus(3S:0) and, during the address 
phase of the Mbus, provides bus control information on Mbus(45:36). The whole bus, Mbus(63:0), is 
used to transfer data during the data phase. 


Pbus 


The Pbus is a 16-bit PC-AT style bus which supports the on-board I/O devices. It consists of 16 data 
lines, PD(15:0), and 19 address lines, PA(18:0). The CPU addresses and exchanges data with the disk, 
Ethernet, modem and saial interfaces and the EPROM and RTC using the Pbus. 



Mbus - Pbus Interface 


The gateway between the Mbus and Pbus is provided by the Mbus to Pbus Interface controller (MPI), 
a Tadpole Technology designed custom ASIC (Applications Specific Integrated Circuit). 

The MPI provides an internal 512byte bidirectional FIFO, address decode facilities fw the Pbus, 
interrupt support and two internal counter/timers. It provides a byte packing int^ace which converts 
between 8-, 16-, 32- and 64-bit accesses used on the Mbus, and 8- and 16-bit accesses used on the 
peripheral bus. This allows the two buses to operate at their optimum speed. 

The MPI provides two data paths between the Mbus and Pbus.. The first path provides direct access 
by the CPU to the Pbus devices, and the second path is via the MPI’s internal 512byte FIFO. The MPI 
also provides DMA support for floppy disk operations. 

In addition to providing an interface between the Mbus and Pbus, the MPI contains a fifteen level 
interrupt controller and two 16-bit counter/timers. The int^rupt controller section is used to consoli¬ 
date the large number of interrupt requests from devices within the SPARCbook, and from the FIFO 
controller and counter/timers within the MPI. Interrupt controller provides the CPU with a code 
which identifies a pending interrupt, and allows individual interrupts to be masked 



CHAPTER THREE 
THE SPARC CPU MODULE 


The SPARC CPU module comprises the CY7C601A integer unit (lU), the CY7C602A floating point 
unit (FPU), and the CY7C604A cache controller and memory management unit (CMU). In the 
SPARCbook implementation, these are carried on a small module along with two CY7C1S7A cache 
storage units (CSU). 


The devices on the SPARCbook CPU module are connected together via a 32-bit virtual address bus 
and a 32-bit data bus. The CMU provides an interface between this bus and the Mbus. The Mbus is a 
SPARC architecture standard 64-bit multiplexed address and data bus that provides the SPARCbook 
with a high bandwidth data path between the CMU and main memory. The CMU performs address 
translations between these buses and provides memory management and cache control functions. The 
two CY7C157A SRAMs provide 64Kbytes of zero wait-state cache memory. 



Figure 3-1 The SPARC CPU Module 
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CY7C601A INTEGER UNIT „ 


The lU is the main processing engine that executes all of the instruction set except for floating point 
operations. 


Instructions Overview 


The CY7C600 architecture supports 62 integer instructions which fall into the following basic catego¬ 
ries: 


• Load and Store Instructions 

• Arithmetic, Logical and Shift Instructions 

• Control Transfer Instructions 

• ReadAVrite Control Registers Instructions 

The load and store instructions are the only instructions which cause the movement of data on the 
Mbus. They use two registers, or a register and a constant, to calculate the memory address involved. 
Halfword accesses must be aligned on 2-byte boundaries, word accesses on 4-byte boundaries, and 
doubleword accesses on 8-byte boundaries. These alignment restrictions greatly speed up memtHy 
access. 

The arithtnetic, logical and shift instructions compute a result that is a function of one or two source 
operands and then place the result non-destructively in a register. They perform arithmetic, logical, or 
shift operations. 

The control transfer instruction category includes jumps, calls, trtg>s, and branches. Control transfers 
are usually delayed until after execution of the next instructions so that the pipeline is not emptied 
every time a control transfer occurs, allowing compilers to be optimized for delayed branching. 

The read/write control register instructions include instructions to read and write the contents of 
various control registers. Generally the source or destination is implied by the instructions. 

In addition to the instruction types within the categories listed above, there are Floating Point instruc¬ 
tions executed by the FPU. 

Table 3-1 provides a summary of the lU instruction set 
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INPUTS 

OPERATION 

Load and Store Instructions 



LDSB(LDSBA*) 

Load Signed Byte 

(from Alternate Space) 

LDSH(LDSHA*) 

Load Signed Halfword 

(from Alternate Space) 

LDUB(LDUBA*) 

Load Unsigned Byte 

(from Alternate Space) 

LDUH(LDUHA*) 

Load Unsigned Halfword 

(from Alternate Space) 

LD(LDA*) 

Load Word 

(from Alternate Space) 

LDD(LDDA*) 

Load Doubleword 

(from Alternate Space) 

LDF 

Load Floating Point 


LDDF 

Load Double Floating Point 


LDDFSR 

Load Floating Point Status Register 


LDC 

Load Coprocessor 


LDDC 

Load Double Coprocessor 


LDDCSR 

Load Coprocessor Status Register 


STB(STBA*) 

Store Byte 

(In Alternate Space) 

STH(STHA*) 

Store Halfword 

(In Alternate Space) 

ST(STA*) 

Store Word 

(In Alternate Space) 

STD(STDA*) 

Store Doubleword 

(In Alternate Space) 

STF 

Store Floating Point 


STDF 

Store Double Floating Point 


STFSR 

Store Boating Point Status Register 


STDFQ* 

Store Double Boating Point Queue 


STC 

Store Coprocessor 


STDC 

Store Double Coprocessor 


STCSR 

Store Coprocessor Status Register 


STDCQ* 

Store Double Coprocessor Queue 


LDSTUB(LDSTUBA*) 

Atomic Load/Store Unsigned Byte 

(In Alternate Space) 

SWAP(SWAPA*) 

Swap r Register With Memory 

(In Alternate Space) 

Arithmetic, Logical and Shift 



ADD(ADDcc) 

Add 

(Modify icc) 

ADDX(ADDXcc) 

Add With Carry 

(Modify icc) 

TADD(TADDccTV) 

Tagged Add and Modify icc 

(and Trap on Overflow) 

MULScc 

Multiply Step and Modify icc 


AND(ANDcc) 

AND 

(Modify icc) 

ANDN(ANDNcc) 

AND NOT 

(Modify icc) 

OR(ORcc) 

OR 

(Modify icc) 

ORN(ORNcc) 

OR NOT 

(Modify icc) 

XOR(XORcc) 

Exclusive OR 

(Modify icc) 

XNOR(XNORcc) 

Exclusive NOR 

(Modify icc) 

SLL 

Shift Left Logical 


SRL 

Shift Right Logical 


SRA 

Shift Right Arithmetic 


SETHI 

Set High 22 Bits of r Register 


SAVE 

Save Caller’s Window 


RESTORE 

Restore Caller’s Window 
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INPUTS 

OPERATION 

Control Transfer 


Bicc 

Branch on Integer Condition Codes 

FBicc 

Branch on Roating Point Condition Codes 

CBccc 

Branch on Coprocessor Condidition Codes 

CALL 

Call 

JMPL 

Jump and Link 

RETT 

Return from Trap 

Ticc 

Trap on Integer Condition Codes 

Read/Write Control Registers 


RDY 

Read Y Register 

RDPSR 

Read Processor State Register 

RDWIM 

Read Window Invalid Mask 

RDTBR 

Read Trap Base Register 

WRY 

Write Y Register 

WRPSR* 

Write Processor State Register 

WRWIM* 

Write Window Invalid Mask 

WRTBR* 

Write Trap Base Register 

UNIMP 

Unimplemented Instruction 

IFLUSH 

Instruction Cache Flush 

FP and Coprocessor Ops 


FPop 

Floating Point Operations 

CPop 

Coprocessor Operations 

* Privileged instuctions 



Table 3-1 Instruction Set Summary 


CY7C601A Internal Registers 


The lU contains two types of registers, working registers (or r registers) and control registers. The r 
registers are used for storage by processes and the control registers are used to track and conU'ol the 
state of the lU. The r registers are contained within a large register file containing one hundred and 
thirty-six 32-bit registers. Eight of these are global registers and are always accessible to a program, 
and the remaining registers are accessed via register windows. 

Figure 3-2 shows the register window organization 
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The register file contains eight register windows, and each window contains twenty-four woricing 
registers. Each register window is divided into three sections called ins, outs, and locals. There are 
eight registers in each of these sections. A window shares its ins and outs with adjacent windows. 

The outs of the previous window are the ins of the current window, and the outs of the current window 
are the ins of the next window. The windows are joined together in a circular stack where the outs of 
the last window are the ins of the first window. 

A current window pointer (CWP) in the processor state register keeps track of which window is 
currently active. The CWP is decremented when the program calls a subroutine that causes the 
processor to access to the next window, and is incremented when the processor returns to the previous 
window. 


Register windows may be marked as invalid in the WIM register, and interrupts may be enabled to 
signal when movement into an invalid window is caused by an instruction. 


Previous Window 



Figure 3-2 Window Register Organization 
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Control Registers 

These include the Processor State Register, the Window Invalid Mask Register, the Trap Base Regis¬ 
ter, the Y Register, illustrated in Figure 3-3, and the Program Counter. 



31 1211 4 3 2 1 0 

Trap Base 
Register 

Figure 3-3 lU Control Registers 

The Processor Status Register (PSR) contains a number of fields that control the processor and hold 
status information. The PSR is modified by SAVE, RESTORE, Ticc and RETT instructions, and also 
by all instructions that modify the condition codes. The privileged instructions RDPSR and WRPSR 
read and write the PSR directly. 

Bits 31:28 impl - identifies the implementation of the lU 

Bits 27:24 ver - identifies the version number of the lU 

Bits 23:20 icc - contains the lU *s condition code and are set by the conditions occurring during integer logic and 

arithmetic operations: 

Bit 23 = Negative flag 
Bit 22 = Zero flag 
Bit 21 = Overflow flag 
Bit 20 = Carry 

Bits 19:14 Reserved 

Bit 13 EC - Enable Coprocessor. This feature should remain disabled 
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Bit 12 EF - Enable Heating Point Unit. This bit enables the FPU. An FP instruction will trap if the EF = 
0, or if an FPU is not fitted. 

Bits 11:8 PIL - identifies the interrupt levels in operation. The lU will only accept interrupts whose level is 
greater than the contents of this Held. 

Bit 7 S - Supervisor. This bit determines whether the processor is in supervisor or user mode. S = 1 selects 

supervisor mode. 

Bit 6 PS - Previous Supervisor. This bit indicates the value of the S bit at the time of the most recent trap. 

Bit 5 ET - Enable Traps. This bit determines whether traps are enabled. A trap automatically resets ET. 

When ET = 0, an interrupt request is ignored and an execution trap causes the lU to halt execution, 
typically resulting in a reset trap. 

Bits 4:0 CWP - Current Window Pointer. This field identifies the current window into the r registers. 

Hardware decrements the pointer when tr^s arc encountered and on SAVE instructions. The pointer 
is incremented on RESTORE and RETT instructions 

Window Invalid Mask Register 

The Window Invalid Mask Register (WIM) allows windows to be marked as invalid in the WIM 
register. Movement into an invalid window caused by a SAVE, RESTORE or RETT instruction will 
cause a window overflow or underflow interrupt to be generated. 

Trap Base Register 

The Trap Base Register contains three fields that generate the address of the trap handler when a trap 
occurs. 

Bits 31:12 Trap Base Address. This contains the most significant 20 bits of the trap table address. 

Bits 11:4 Trap Type. This field is written by hardware at the time of a trap. It provides an offset into the trap 

table. 

Bits 3:0 Reserved - Should always be written as zeros. 

Y Register 

The Y Register is used to store the partial product during multi-step instructions. 

Program Counter 

The Program Counter (PC) contains the address of the instruction being executed. The next Program 
Counter contains the address of the next instruction to be executed. 




Traps and Interrupts 


The CY7C6(X) design supports a full set of traps and interrupts. They are handled by a table that 
supports 128 hardware and 128 software trtq)s. Even though floating-point instructions can execute 
concurrently with integer instructions, floating-point traps are precise because the FPU supplies (from 
the table) the address of the instruction that failed. 

The lU supports both asynchronous tr£q)s (interrupts) and synchronous traps (error conditions and trap 
instructions). Tr^s transf^ control to an offset within the trtq) table. The base address of the table is 
specified by the Trap Base Register and the offset is a function of the trtq) type. Traps are taken 
before the current instruction causes any changes visible to the programmer and can therefore be 
considered to occur between instructions. 

Table 3-2 shows priority levels of the exceptions and traps. 

Interrupts from the peripheral devices within the SPARCbook are controlled and prioritized by the 
Mbus to Pbus interftK;e (MPI) ASIC (see Chapter 5). 


Memory Protection 


The CY7C600 (tesign provides memory protection, which is essential for smooth multitasking 
operation. Memory protection makes it impossible for user programs to corrupt the system, other user 
programs, or themselves. 

The lU suiqmrts a multitasking operation system by providing user and supervisor modes. Some* 
instructions are privileged and can only be executed while the processor is in supervisor mode. 
Changing from user to supervisor mode requires taking a hardware interrupt or executing a trap 
instruction. This instruction execution protection ensures that user programs cannot accidentally alter 
the state of the machine with respect to its peripherals. 




TRAP 

PRIORITY 

OFFSET 

Reset 

1 

?? 

Instruction access exception 

2 

0x01 

Illegal Instruction 

3 

0x02 

Privileged Instruction 

4 

0x03 

FP Disabled 

5 

0x04 

CP Disabled 

5 

0x24 

Window Overflow 

6 

0x05 

Window Underflow 

7 

0x06 

Unaligned Memory Address 

8 

0x07 

FP Exception 

9 

0x08 

CP Exception 

9 

0x28 

Data Access Exception 

10 

0x09 

Tag Overflow 

11 

OxOA 

Trap Instruction 

12 

0x80 OxFF 

Interrupt Level 15 - Microcontrollar/Floppy Disk 

13 

OxlF 

Interrupt Level 14 - Battery Power Low 

14 

OxlE 

Interrupt Level 13 - MPI (Counter/timer 0) 

15 

OxlD 

Litemipt Level 12 - MPI (Counter/timer 1) 

16 

OxlC 

Interrupt Level 11 - MPI (Keyboard buffe) 

17 

OxlB 

Interrupt Level 10 - Mouse 

18 

OxlA 

Interrupt Level 9 - Serial Port 

19 

0x19 

Interrupt Level 8 - Modem 

20 

0x18 

Interrupt Level 7 - Ethernet Interface 

21 

0x17 

Interrupt Level 6 - VGA Controller 

22 

0x16 

Interrupt Level 5 - Hard Disk Interface 

23 

0x15 

Interrupt Level 4 - MPI (FIFO Full/Empty) 

24 

0x14 

Interrupt Level 3 - MPI (FIFO Op Complete) 

25 

0x13 

Interrupt Level 2 - Microcontroller/Floppy Disk 

26 

0x12 

Interrupt Level 1 - Centronics Interface 

27 

0x11 

Implementation Dependent Exceptions 

Dependent 

0x60 - 7F 


Table 3-2 Trap Table 








FLOATING POINT UNIT 


The FPU provides high-performance, IEEE STD-754 compatible single- and double-precision 
floating-point calculations for CY7C600 systems and is designed to operate concurrently with the lU. 
All address and control signals for memory accesses by the FPU are supplied by the lU. 


Overview 


The lU and FPU are able to execute instructions simultaneously. The FPU performs all floating-point 
calculations with its own set of registers and arithmetic and logic unit. 

Roating-point instructions are addressed by the lU, and are simultaneously latched from the data bus 
by both it and the FPU. Roating-point instructions are concurrently decoded by the lU and the FPU, 
but do not begin executing in the FPU until after the instruction is enabled by a signal from the lU. 
Pending and currently executing FP instructions are placed in an on-chip queue while the lU continues 
to execute non-floating-point instructions. 


Floating Point Registers 


The FPU contains thirty-two 32-bit floating-point F registers. These form a 32 x 32-bit register file. 
The contents of these registers are transferred to and from external memory under control of the lU 
using floating-point load/store instructions. Addresses and control signals for data accesses during a 
floating-point load or store are supplied by the lU, while the FPU supplies or receives the data. 



Figure 3-4 F Registers 


40 






Although the FPU operates concurrently with the lU, a program containing floating-point computa¬ 
tions generates results as if the instructions were being executed sequentially. 

Figure 3-4 illustrates the F registers. 

A single F register is able to one single-precision operand, two are required to hold a double precision 
operand, and four are required to hold and extended precision operand. 


Floating-Point State Register 


The floating-point status register (FSR) contains mode and status information about the FPU. It is 
read and written using the STFSR and LDFSR. Figure 3-5 illustrates the FSR. 


FPU State 
Register 


31 30 29 28 27 


23 2221 


17 16 


14 13 12 11 10 9 


5 4 


AU 


RD RP 


fee 


Figure 3-5 FSR 

Bits 31:30 RD - Rounding Direction. These select the rounding direction for floating-point results: 
00 = Nearest 
01 = Zero 

10 = +oo 

11 = -oo 

Bits 29:28 RP - Extended Rounding Precision 
00 = Extended 
01 = Single 

10 = Double 

11 = Unused 


Bits 27:23 TEM - Trap Enable Mask. These are enable bits for each of the five floating-point exceptions: 

Bit 27 = Invalid Operation Trap Mask 
Bit 26 = Overflow Trap Mask 
Bit 25 = Underflow Trap Mask 
Bit 24 = Divide by Zero Trap Mask 
Bit 23 = Inexact Trap Mask 

Bit 22 AU-Abrupt Underflow. Whenset, this bit causes denormalizedFP operands or results to be rounded 

to zero. 


Bits 21:17 Reserved 
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Bits 16:14 

Bit 13 

Bit 12 
Bits 11:10 

Bits 9:5 

Bits 4:0 


ftt - Floating-Point Trap Type. These indicate the type of exception: 

0 = None 

1 = lEE E Exception 

2 = Unfinished FP operation 

3 = Unimplemented FP operation 

4 = Sequence Error 
5-F = reserved 

qne - Queue Not Empty. When set, this bit indicates that the FP queue is not empty following an FP 
exception or STDFQ instruction was executed. 

Reserved 

fee - FPU Condition Codes. These bits are updated by FP compare instructions: 

00 = fsrl = fsr2 
01 = fsrl < fsr2 

10 = fsrl > fsr2 

11 = fsrl ? fsr2 (unordered) 

aexc - Accrued Exception Bits. 

Bit 9 = Accrued Invalid Operation 
Bit 8 = Accrued Overflow 
Bit 7 = Accrued Underflow 
Bit 6 = Accrued Divide by Zero 
Bit 5 = Accrued Inexact 

eexe - Current Exception Bits 
Bit 4 = Current Invalid Operation 
Bit 3 = Current Overflow 
Bit 2 = Current Underflow 
Bit 1 = Curr«it Divide by Zero 
Bit 0 = Current Inexact 
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CACHE CONTROLLER AND MEMORY MANAGEMENT UNIT 


The interface between the bus, on which the lU, FPU and cache memory reside, and the Mbus, on 
which the main memory and peripheral interfaces reside, is provided by a CY7C604 Cache Controller 
and Memory Management Unit (CMU). This device inovides translation between the 32-bit virtual 
addresses used on the CPU module and 36-bit physic^ addresses used on the Mbus. It provides 
hardware support for a demand-paged virtual memory environment for the lU. The Page size is fixed 
at 4Kbytes. The CMU also manages a 64Kbyte cache memory. 


Memory Management Unit 


The memory management unit (MMU) conforms to the standard SPARC architecture definition for 
memory management 

The MMU provides virtual to physical address translation using a translation lookaside buffer (TLB). 
This is an area of specialized on-chip memory containing sixty-four Page Table Entries (PTE) as 
shown in Figure 3-6. 




Virtual Section 

_/V_ 




Physical Section 

_/s_ 


■N 


VA(31:12) 

CXN(11:0) 

PPN(35:12) 

C |M 

ACC(2:0) 

ST(1:0) 

3 



64 TL 

3E 

itrie 

j 



1 VA(31:12) 

CXN(11:0) 1 PPN(35:12) 

C M 

ACC(2:0) 

ST(1:0) 

til 


Figure 3-6 Translation Lookaside Buffer 

Each entry within the TLB contains a virtual section and a physical section. Hie virtual section 
comprises a virtual address field, for comparison with VA(31:12), and 12-bit context field, for 
comparison with the contents of the context register. 
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The physical section contains the physical address field, PPN(35:12), a cache control bit, a modified 
bit, a 3-bit access protection field, a translation control field, and a valid bit 

Bits (31; 12) of the virtual address are translated and expanded to physical address bits (35:12). 

During an access by the lU, the virtual address supplied by the lU and the contents of the context 
register are compared with the virtual section of all sixty-four entries simultaneously. When a match 
is found (or a “hit” occurs), the physical address field PPN(3S: 12) supplies the address of a 4Kbyte 
page in memory. Virtual address bits A(11:00) from the lU are passed through unchanged to supply a 
byte offset. This is illustrated in Figure 3-7. Each hit TLB entry is checked for memory protection 
attributes automatically and violations are reported to the lU as memory exceptions. 


31 24 23 18 17 12 11 0 



Figure 3-7 Address Translation 

If the virtual address from the lU does not match an entry in the TLB, the CMU automatically per¬ 
forms a search (or table walk) through a translation table in main memory to obtain an address 
translation. 

The translation table forms a tree structure in main memory as illustrated in Figure 3-8. The Context 
Pointer register provides a pointer to the context table, and the context register provides an index to 
the Root Pointer, which in turn points to a level 1 page table. Index 1 firom the virtual address selects 
an entry within Level 1 pointing to a level 2 page table, where Index 2 selects a pointer to a level 3 
table. Index 3 then selects one of the entries in the level 3 table which should point to a 4Kbyte 
memory page. 
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When a page table pointer (FTP) is encountered within the tables, the search continues to the next 
lower level. If a page table entry (PTE) is found, the search is terminated and the entry is stored in the 
TLB. If no PTE is found at all, a synchronous fault exception is signalled to the lU. 

Tlie PTE provides a pointer to a physical page while the lower 12 bits of the virtual address provides 
an offset. 

The level at which a table walk tominates (i.e. a PTE is found) is related to the size of addressing 
region associated with the entry. A table walk which finds a PTE in the context table corresponds to a 
region of 4Gbytes. A PTE in level 1 corresponds to a 16Mbyte region, or 256Kbyte in level 2, or 
4Kbyte in level 3. The virtual address bits not used to inttex table entries are used to supply the page 
offset. 
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Figure 3-8 A Three Level Table Walk in Memory 







Figure 3-8 shows a table walk which uses three page table levels. In this example A(31:12) from the 
virtual address are used to index the page tables, and A(11:0) supply an offset address into the selected 
memory page 


Figure 3-9 shows a table walk which terminates at level 2. In this case A(31:18) are used as index 
bits, and A(17:0) provide an offset address into the selected page. 
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Cache Controller 


The cache controller provides access control for the 64Kbyte cache memory implemented on the CPU 
module. 

The cache is organized with 2048 cache lines of 32bytes each, as illustrated in Figure 3-10. The CMU 
provides on-chip storage for 2048 cache address tags, one for each line. The tag entries can be directly 
written or read by the processor. 


8 X 32-bit Words 



Figure 3-10 Cache Memory Organization 

During an lU read operation, virtual address bits VA(1S:S) select one of the 2048 lines and, at the 
same time, one of the cache tags maintained by the CMU. If the virtual address within a cache tag 
matches with VA(15:5), and the context field matches with context register, a hit occurs. The cache 
line represented by the valid tag is selected by the CMU and one or more of the 32bytes in the cache 
line are selected by VA(4:0) from the lU. If a miss occurs the CMU reads in a new cache line from 
main memory. Burst accesses are used by the CMU to fill cache lines. Burst accesses are always 64- 
bits wide and always consist of an address phase followed by four data transfer phases (32bytes in 
total). The lU is held until the CMU has loaded the new cache line, but this is completely transparent 
to the programmer. 












Figure 3-11 illustrates cache tag comparison by the CMU. 



Figure 3-11 Cache Tag Comparison 
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CY7CI57A CACHE STORAGE UNIT 


The CY7C157A cache storage unit is a 16Kbyte x 16 SRAM CSU designed to interface easily to a 
CY7C600 processor and provide maximum performance. The CSU is a specialized device which has 
registered address inputs, and latched data inputs and ouq)uts as well as a self-timed write pulse. 

The device has a single clock that controls loading of the address registers, data input latches, data 
output latches, pipeline craitrol latch, and chip enable register. The chip enable is clocked into a 
register and pipeline through a control register to condition the output enable. This pipeline design 
allows a cache that works as an extension of the internal instruction pipeline of the lU. 

Figure 3-12 shows the internal architecture of a CY7C157A CSU chip. 



Figure 3-12 CSU Internal Architecture 








CHAPTER FOUR 
MAIN MEMORY 


The SPARCbook may be manufactured with either SMbytes or 32Mbytes of main memory which 
provides a 64-bit wide storage for the SPARC CPU. The SPARCbook’s Base board is always fully 
populated with DRAM chips. It is fitted with an array of sixteen 1Mbit x 4 DRAMs, if equiiq)ed with 
SMbytes of memory, or the same numbo* of 4Mbit x 4 DRAMs if equipped with 32Mbytes. Field 
upgrades are not possible. Two additional DRAMs, of the same size as those used in the main 
memory array, provide storage for parity bits generated for each byte location. 

Figure 4-1 shows the architecture of the main memory. 
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FUNCTIONAL DESCRIPTION 


Memory Accesses 

All main memory accesses in the SPARCbook are initiated by the SPARC CPU. It supports single 
cycle reads and writes of 8,16,32 and 64bits, and also burst cycles. 

Access Control and memory refresh for the main memory array is provided by a powerful program¬ 
mable logic device (PLD) containing the equivalent of 1800 logic gates. This, in conjunction with a 
custom 32-bit buffer chip, provides full addressing support for all of the SPARC CPU’s memory 
access cycles. 

Parity Checking 

During writes to DRAM, parity bits are generated for each byte location written to. When the data is 
read out again, the parity bits and the stored data are checked. Errors in any byte lane are signalled to 
the PLC which in turn signals an uncorrectable error to the SPARC CPU. Parity checking is enabled 
via the microcontroll^ (see Chapter 6), and parity error interrupts are enabled via the MPI (see 
Chapter 5). 




CHAPTER 5 

MBUS TO PBUS INTERFACE 


The SPARCbook baseboard is based on a dual bus architecture (see Chapter 2). The SPARC CPU and 
main memory are located on the SPARC architecture standard 64-bit Mbus, and the peripheral 
controllers are located on the 16-bit PC-AT style Pbus. 

In the SPARCbook, transactions between these two buses are controlled by the Mbus to Pbus Inter¬ 
face controller (MPI). This is an implication specific integrated circuit (ASIC) designed by Tadpole 
Technology. 



Exlemal 

Intenupts 

1RQ(9:0) 


Figure 5-1 MPI Architecture 
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INTRODUCTION TO THE MPI 


The Mbus and Pbus have very diverse characteristics so that interactions between them are complex. 
The Mbus is a 64-bit multiplexed data and address bus which operates at 2SMHz ami is capable of 
sustaining a data transfer rate of 40Mbyte/s in and out of main memory. The SPARC CPU also uses 
part of the Mbus to supply control signals during the address phase of a transfer operation. 

The Pbus uses separate address and data buses, and separate control lines to control transfers. It is 
also very much slower than the Mbus. 

The MPI contains data packing registers which allow direct 64-bit accesses by the SPARC CPU to the 
8- and 16-bit peripheral controllers on the Pbus by converting 8-, 16-, 32- and 64-bit accesses on the 
Mbus into the tq)propriate number of single cycle accesses on the Pbus. It also contains a S12byte 
FIFO buffer which extends this access conversion to support Mbus burst cycles. 

The MPI provides complete address decode facilities for the Pbus (the peripheral address space) and 
converts Ae control information from the Mbus into the Pbus control signals necessary to support 
accesses to the AT style peripheral controllers employed in the SPARCbook. In addition, the MPI 
provides the SPARCbook with a 15 level interrupt controller and two 16-bit counter/timers 


PERIPHERAL BUS INTERFACE 


The MPI is the only Pbus master device in the SPARCbook, no other device is able to initiate a data 
transfer cycle on the Pbus. Data may be transferred to and from the Pbus using 8- or 16-bit accesses 
by one of two independent paths. The first is a direct access path into the peripheral address space, and 
the second is via the internal FIFO. 


Direct Operation 


The direct access path into the peripheral address space takes a single transfer of 8,16,32 or 64bits 
bom the host bus and performs the corresponding number of transfers required on the Peiiphml bus. 
The Mbus transfers and corresponding Pbus transfers supported are shown in Table 5-1. 


54 



On a write cycle, the MPI allows write-posting from the Mbus. It latches the data presented into 
internal buffers and completes the Mbus transaction immediately, allowing the SPARC CPU to use 
the Mbus fo main memory accesses. In the mean time, the MPI p^orms the appropriate number of 
write cycles to the addressed periph^al. The only possible errors on write-posted cycles are accesses 
by the CPU to non-resptmding or illegal locations, which are immediately decoded by the MPI and 
signalled as an unconectable Mbus error. 

When the SPARC CPU executes a read opmtion to the peripheral address space, the MPI holds the 
Mbus until the requested data has been re^ finom the Pbus into tlw internal buffers and then completes 
the Mbus cycle. Up to eight Pbus read opmtions (for a single 64-bit Mbus op^tion) are carried out 
for each Mbus read opmdon. 


MBUS TRANSFER 

PORT SIZE 

PBUS TRANSFER 

Byte on byte boundary 

Byte on byte boundary 

Halfword on halfword boundary 
Halfword on halfword boundary 

Word on wwd boundary 

Word on word boundary 

Doubleword on doubleword boundary 
Doubleword on doubleword boundary 

Byte 

Halfword 

Byte 

Halfword 

Byte 

Halfword 

Byte 

Halfword 

1 Byte transfer 

1 Byte transfer (lower or upp^) 

2 Byte transfers 

1 Halfword transfer 

4 Byte transfers 

2 Ifalfword transfers 

8 Byte transfers 

4 I^ilfword transfers 

Note: Halfword = 16bits, Word = 32bits, Doubleword ® 64bits 


Table 5-1 Conversion of Mbus Transfers to Pbus Transfers 





FIFO Operations 


The second means of data transfer to and from the host bus is by using the MPI’s internal FIFO. 

Mbus transfers to and from the FIFO port are only permitted using 64-bit transfers. 

FIFO operations are initiated by the SPARC CPU. To execute a FIFO operation, the SPARC CPU 
must set up control registers in the MPI to specify the following parameters; 

■ The Peripheral address space start address 

* The number of bytes to be transferred 

• The direction of transfer (read or write) 

• Incrementing or static Pbus addressing 

* Pbus DMA (floppy disk operations only) or polled operation 

A FIFO operation is started by setting the FSTART bit in the FIFO control register. 

Read Transactions 

After the FIFO control registers have been used to initiate a read operation, the MPI executes a series 
of read opoations on the Pbus, transferring the data into the FIFO. The operation is complete when 
either the FIFO becomes full or the byte count in the FCOUNT register reaches zero, signifying that 
the specified number of bytes have bwn transferred. The FIFO full and FCOUNT equals zero 
conditions are signalled to the SPARC CPU with interrupts. 

In polled mode operations, the data transfers proceeds at the fastest rate permitted by the peripherals. 
In DMA mode, the DRQ/DACK lines are used to control the peripheral bus transfers. This latter mode 
is intended for flqjpy disk transfers. 

Once in the FIFO, the data may be read out by the SPARC CPU using 64-bit single cycle or burst 
transfers. While data may be read from the FIFO as soon as it is available, the SPARC CPU should 
not read more data than has been read from the Pbus (this can be checked by using the FCOUNT 
status regist^). Reading more data than is available in the FIFO will result in a FIFO Empty interrupt 
(if it is enabled), and undefined data being returned. 

Once the required number of bytes have been read by the CPU, Pbus uansfers are stopped and the 
host is interrupted (under software control). 

Write Transactions 

For a write opoation the host may write up to 512bytes into the FIFO data register using 64-bit single 
or burst transfers. Bursts of up to 32bytes (four Mbus data transfer cycles) are supported without wait 
states. 
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The FIFO Control register contains full and empty flags which may be programmed to generate 
interrupts. The MPI may be programmed to interrupt the CPU when the FIFO Full flag or FIFO 
Empty flag in the FIFO Contfol register become set. 

llie FIFO Start bit in the FIFO Control register must be set in order to allow a FIFO operation to 
proceed. Then, once the CPU writes data into the FIFO the corresponding Pbus transactions com¬ 
mence, beginning at the address specified in the FIFO Start Address register. 

A special iterating mode allows data in the FIFO to be written directly to the peripheral bus (a write 
operation with no data supplied by the SPARC CPU). 

NOTES: 

1 FIFO transfers may not be carried out over a 1Kbyte peripheral address boundary. 

2 At any time the FIFO may be reset by asserting a bit in the System Reset Register. This causes the FIFO pointers 
and counters to be reset and creates an empty FIFO. 

3 Mbus transfers other than those in Table S-1 (eg misaligned transfers) are not supported. 


Peripheral Space Address Decoder 


All addresses for the Pbus are decoded by the MPI. The MPI divides the Pbus address space into six 
2Mbyte regions, resulting in the address mt^ shown in Figure S-2. 

In four regions the MPI ass^ the chip select for one device, while the remaining two are assigned to 
provide one 8-bit region and one 16-bit Pbus I/O region. Accesses to non-responding locations will 
return undefined data on reads and write to undefined locations on writes. 

The MPI does not provide a chip select signal for the 82C710 UPC, which is used to provide control 
of the disk and external mouse interface. This device is accessible at various locations within the 8- 
and 16-bit access regions (see Chapter 7). 
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OxOOCCFFFFF 


8-bit Pbus Operations 


OxOOCCOOOOO 


OxOOCSOOOOO 


0x000600000 


0x000400000 


0x000200000 


0x000000000 

Figure 5-2 Pbus Memory Map 


16-bit Pbus Operations 
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COUNTER-TIMERS 


The MPI incorporates two general purpose 32-bit counterAimers, CTO and CTl for software use, and 
a bus timeout timer which prevents the SPARCbook from stalling due to an access to a non-respond¬ 
ing location. These are illustrated in Figure S-3. 
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Figure 5-3 MPI CountCT Timers 








System Timers 


The two general purpose counter/timers each consist of a 32-bit up counter, a 32-bit time constant 
register and a counter control register. These are clocked from a IMHz clock, internally generated by 
the MPI, giving a timing resolution of Ips. The timers count up and may be used to generate an 
interrupt after a programmable delay. 

The timers can be chained to create a single 64-bit counter/timer. In this mode of operation, Timw 0 
supplies the timing for Timer 1. 

The timers may be programmed to operate in either one-shot mode or continuous mode. In one-shot 
mode the timer counts up from a preloaded value and completes the count when it reaches one after 
passing zero. 

In continuous mode, the timer is reloaded with the preset count value each time it reaches zero and 
continues counting, gen^ting a poiodic interrupt each time zero is reached. 

Further information is provided in the register descriptions in this chapter. 


Bus Timeout Timer 


The MPI also contains a bus timeout timer (see Interrupts below). This timer monitOTS all Mbus 
transactions. Any Mbus transacticni that is not completed after detection of four CLK32K clocks 
causes termination of the cycle and an Mbus Error. This corresponds to a timeout of approximately 
12Sps. The bus timeout timer has a fixed timeout period and signals an Mbus error if this period 
expires. 

This facility is used fw all Mbus cycles and is not limited to accesses to the MPI control registers or to 
the peripheral address space. 


SERIAL HO PORT 


The MPI contains a single channel serial interface which operates in conjunction with the 
microcontroller to provide an interface to the keyboard. 



Serial Input 


A single serial input line receives asynchronous data at 976.6 baud (1.024nis period) from the key¬ 
board microcontroller. Data is formatted as 8 data bits with one start bit (0) and one stop bit (1), with 
the least significant bit transfmed first. No other data formats are pomitted. Up to three charact^ are 
buffered by the MPI. An interrupt may be generated if there are any received characters in the buffer. 


Serial Output 


A single serial output line transmits asynchronous data at 976.6 baud to the keyboard microcontroller. 
Data is formatted as 8 data bits with one start bit (0) and one stop bit (1). No oth^ data formats are 
permitted. A status register contains a busy bit If the busy bit is not asserted the host may write a 
single byte to the transmit register. The busy bit will be asserted until the transmitter buffer becomes 
available again. 


POWER MANAGEMENT FUNCTIONS 


The MPI incorporates a power management unit (PMU) which controls the SPARCbook internal 
clocks and power supply to the p^pheral controller devices. 

PMl is used to switch off the main power to the system. 


Clock Control 


The MPI controls the main Mbus clock, MCLKO, to which all Mbus transactions are synchronized. 
The MPI performs the following functions using the input reference 25MHz. 

Normal Operation 

MCLKO & MCLKl are generated from CLK25M and operate at 25MHz. A IMHz timing reforence 
for the counter/timers is derived from CLK25M. 

Slow Operation 

MCLKO & MCLKl are generated from CLK25M but are reduced to 12.5MHz. The timing reference 
for the counter/timers remains unchanged. 





Stop Operation 

MCLKO is stopped in the high state at the end of the cycle after the deasseition of /MRDY. MCLKl is 
output at 12.5MHz. The timing reference for the counter/timers is unchanged. 

Pause Operation 

MCLKl is not affected (remains at 12.S or 2SMHz). MCLKO can be supped temporarily in (me of 
two software selectable (via the relevant CLK_CTL register bits) mcxles. The first is the INTPAUSE 
mode. In this mode the MCLKO signal is held high (stopped) from the clock after the MAS strobe 
until the clock before the MRDY or MERR cycle termination for accesses which are to the MPI. 

In the second, EXTPAUSE mode, the MCLKO is held high (stopped) for a programmable number of 
clocks from 0 (default) to 7 after the MAS cycle when the MPI is not being addressed. This is used to 
conserve power during initial memory accesses. Note that in the INTPAUSE mcxle the Mbus timeout 
will still operate to tominate the cycle if required. 


INTERRUPT CONTROLLER 


The MPI incorporates an interrupt controller. This consists of a iniority enccxler and Interrupt Mask 
registers. The interrupt controller is illustrated in Figure S-4. 



Figure 5-4 SPARCbook Interrupt Architecture 
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Table 5-2 shows the interrupt sources from the SPARCbook's devices and from within the MPI itself. 

The MPI performs a simple priority encoding of the sixteen interrupt sources to four interrupt request 
lines to the SPARC CPU, IRL(3:0). The MPI external interrupts are all level sensitive, and may be 
individually programmed to be active high or active low. Each interrupt may be individually enabled 
or masked. At power up all interrupts are masked. 

After an Mbus clock stop operation (under CPU control), the activation of any non-maskable inter¬ 
rupts will automaticaUy restart the MCLK clock in the same mode (2SMHz or 12.5MHz) as when it 
was halted. 

IRQ9 is a special case. It is latched internally within the MPI when it has been ass^ted for one clock 
period. The latched signal is fed into the interrupt priority circuit The latch (and the interrupt) is 
cleared by writing to the appropriate Interrupt Acknowledge bit 


LABEL 

SOURCE 

IRL(3:0) 

DEVICE 

IRQ9 

External 

nil 

CMU 

IRQ8 

External 

1110 

Power Low/Hoppy Disk 

CTO 

Internal 

1101 

Countw Timer 0 

CTl 

Internal 

1100 

Counts Timer 1 

KBD 

Internal 

1011 

Keyboard Buffer 

IRQ? 

External 

1010 

Ext^nal Mouse 

IRQ6 

External 

1001 

Serial 

IRQ5 

Extmial 

1000 

Modem 

IRQ4 

External 

0111 

Ethernet 

IRQ3 

External 

0110 

Display 

IRQ2 

External 

0101 

Hard Disk 

FEE 

Internal 

0100 

FIFO Full/Empty 

FOP 

Internal 

0011 

FIFO Operation complete (FCOUNT=0) 

IRQl 

External 

0010 

Power Low/H(q)py Disk 

IRQO 

External 

0001 

Centronics 



0000 

No Interrupt 


Table 5-2 SPARCbook Interrupt Sources 




INTERNAL REGISTERS 


The MPI contains twenty control registers which affect the activity of the elements that the MPI 
contains. In addition to the control registers, the MPI provides a twenty first location which is used to 
move data into (for writes), and out of (for reads), the FIFO. 

Table S-3 summarizes the internal address m^ of the MPI. It provides the address, label, name and 
size of each register. The size refers to the darn width that must be used when accessing the register. 


ADDRESS 

LABEL 

NAME 

ACCESS 

SIZE 

OxOODOOOOOO 

MERR_STATUS 

Mbus Error Status 

RO 

8-bit 

OxOODOOOOlO 

CTO.TIME 

Set Count CTO 

R/W 

32-bit 

OxOODOOOOlS 

CTO.VALUE 

Current Count CTO 

RO 

32-bit 

OxOOD000020 

CTO_CONTROL 

Control CTO 

R/W 

8-bit 

0x00D000028 

CT1_TIME 

Set Count CTl 

R/W 

32-bit 

0x00D000030 

CTl.VALUE 

Current Count CTl 

RO 

32-bit 

0x00D000038 

CTl_CONTROL 

Control CTl 

R/W 

8-bit 

OxOODOOOOSO 

INT_PEND 

Interrupt Pending 

RO 

32-bit 

0x(X)D0(X)058 

INT_POLARITY 

Interrupt Polarity 

R/W 

32-bit 

OxOODOOOOeO 

INT_ENABLE 

Interrupt Enable 

R/W 

32-bit 

0x(X)D000068 

INT_ACK 

Interrupt Acknowledge 

WO 

32-bit 

OxOODOOOOTO 

KBDDATA 

Serial Receive Port 

RO 

8-bit 

0x00D000088 

KBDSTATUS 

Serial Receive Status 

RO 

8-bit 

0x0OD00009O 

TXDATA 

Serial Transmit Port 

WO 

8-bit 

Ox00DOO0O98 

TXSTATUS 

Serial Transmit Status 

RO 

8-bit 

OxOODOOOOAO 

RESET 

Reset 

R/W 

8-bit 

OxOODOO(X)A8 

CLK_CTL 

Clock Control 

R/W 

8-bit 

0x00D0000B8 

PM_PORT 

Power Down 

WO 

8-bit 

OxOOIXXXXlCO 

FIFO_START 

FIFO Start Address 

R/W 

32-bit 

Ox(X)DOOOOC8 

FIFO.CONTROL 

FIFO Control 

R/W 

32-bit 

OxOODOOOOF8 

FIFO.DATA 

FIFO Data 

R/W 

64-bit only 


Table 5-3 MPI Internal Registers 
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FIFO Control Registers 

FIFO control registers are used to program the FIFO. 

FIFO Start Address Register 

This register is used to specify the Peripheral Space start address for a FIFO transaction. The first 
Pbus transaction accesses this address. Subsequent transactions will either automatically increment the 
Pbus address by the size of the port (by 1 for byte, by 2 for halfword), or retain tlw same address if the 
FNOINC bit is set in die FIFO_CONTROL register. 

Note that although only 24 bits are valid the full address may be written into this regist^, the upper 
bits are ignored. On a read, address bit A(20) is set (signifying FIFO address). A(19) is hardwired to 0. 

Bits 31:24 Reserved 

Bits 23:0 Address Bits 23:0 

31 30 29 28 27 26 25 24 23 0 

QiiO(H>OOOOCO 


Bits 31:24 Reserved 

Figure 5-5 FIFO Start Address Register 
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FIFO Control Register 

This register is used to to control and initiate FIFO qierations. It also contains status bits to reflect the 
state of the FIFO. 



Figure 5-6 FIFO Control Register 








Bits 31:20 Reserved 


I 




Bit 19 FULL 

1 = FIFO is full 

Bit 18 EMPTY 

1 = FIFO is empty 

Bit 17 FNHD 

0 = 

1 = 

Bit 16 ENFULL 

0 = Disable FIFO FUll interrupts 
1 = Enable FIFO FULL interrupts 

Bit 15 ENFEMPTY 

0 = Disable FIFO EMPTY interrupts 
1 = Enable FIFO EMPTY interrupts 

Bit 14 FSTART 

0 = Disable FIFO operations 
1 = Enable FIFO operations 

Bit 13 FRNW 

0 = CPU write to Pbus 
1 = CPU read from Pbus 

Bit 12 PENT 

0 = Disable FCOUNT equals interrupts 
1 = Enable FCOUNT equals zero interrupt 

Bit 11 FDMA 

0 = Polled FIFO operations 
1 = DMA FIFO operations (floppy disk only) 

Bit 10 FNOINC 

0 = Use incrementing Pbus address 
1 = Use same Pbus address 

Bit 9:0 FCOUNT Bits 9:0 - Number of bytes to be transferred. 


n 
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A FIFO Full/Empty interrupt will cause the FEMPTY and FFULL bits to be frozen until the register is 
read by the CPU. These bits are set on a transition to the EMPTY or FULL state. They will not cause 
a new interrupt if the associated state is still true after being acknowledged, or if enabled when the 
FIFO is already in the Full/Empty state. 

An operation is initiated by programming the FIFO Start Address register, programming the FIFO 
Control register parameters and setting the FSTART bit The FSTART bit may be set in the same 
CPU as the programming of the rest of the FIFO Control register. 

Initially, FCOUNT must be a multiple of 8. FCOUNT is decremented by 1 (for byte operations) or 2 
(for halfword operations) for each peripheral bus read or write. The FINT bit determines whether a 
transition on FCOUNT to zero causes a FOP interrupL 

FIFO Data Register 

TTie FIFO_D ATA register is used for host FIFO data transfer operations. Only doubleword (64-bit) or 
32byte burst operations are allowed to this register. FIFO data will be transferred into or out of the 
FIFO. Data is aligned to SPARC conventions. Full byte swapping and packingAinpacking between 
the Peripheral bus and the Mbus is performed within the MPI. Note that byte swaiq)ing cannot deal 
with addresses or pointers passed between the Mbus and Pbus. 


Timer Control Registers 


Set Count CTO (CTl) 

These are read-write registers used to set the count value for the associated counter. The value is 
specified in microseconds. 

ft 

Counter Current Value 

These registers provide the current Counter Value for the associated counter. They are read only 
registers, a write has no effect. 

Counter 0 Control 

This register provides control for Counter 0. The COSTART bit may be set in the same operation as 
the setting of the rest of the control register. 



Figure 5-7 Counter 0 Control Register 
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Bits 7:3 


Reserved 


Bit 2 COCONT 

0 = Counter continues on zero to 1 (one shot) 

1 = Counter reloads from CT0_TIME and continues running 

Bit 1 COINTEN 

0 = Disable interrupt on zero 
1 = Enable interrupt on zero 

BitO COSTART 

0 = Stop counter 
1 = Start counter 

Counter 1 Control 

This register provides control for Counter 1. The CISTART bit may be set in the same operation as 
the setting of the rest of the control register. 

7 6 5 4 3 2 1 0 

0x000000038 


Figure 5-8 Counter 1 Control Register 

Bits 7:3 Reserved 

Bit 3 CICONT 

0 = Counter continues on zero to 1 (one shot) 

1 = Counter reloads from CTOJITME and continues running 

Bit 2 ClINTEN 

0 = Disable interrupt on zero 
1 = Enable interrupt on zero 

Bit 1 CISTART 

0 = Stop counter 
1 = Start counter 

BitO CIUNK 

0 = Count from IMHz Clock 
1 = Count from CTO 
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POWER MANAGEMENT CONTROL REGISTERS 


Power Management Port 

This legister is used to control the state of the power management line provided by the MPI. It is an 8- 
bit read/write register containing one valid bit in DO. If this bit is set the PMI line is asserted (high) 
and the system is powered down. 

Clock Control Register 

This register performs the MCLK management for the main CPU clock. Note that the only way of 
restarting MCLKO after MCLKSTOP has been asserted is by the receipt of a non-masked interrupt. 
Hie programmer should therefore be careful to ensure that this will happen or the system will hang. 

When an interrupt is received MCLKO is automatically restarted and the MCLKSTOP bit is cleared. 
Note that when the clock restarts both MCLKO-1 will be restarted at 2SMHz if MCLK12 is reset, and 
at 12.5MHz if MCLK12 is set 


7 6 5 4 3 2 1 0 

□ 

PAUSECNT 

□ 

L 

□ 

□ 


-TEST 


Figure 5-9 Clock Control Register 


EXTPAUSB- 

INTPAUSE- 

MCLKSTOP- 

MCLK12- 


Bit 7 TEST 

Must be set to 0 

Bits 6:4 PAUSECNT 

001 -111= Number of MCLKO clock cycles to stop during EXTPAUSE. 
0 = do not pause clock 

Bits EXTPAUSE 

1 = Enable EXTPAUSE clock stopping during other Mbus accesses 
Bit D2 INTPAUSE 

1 = Enable INTPAUSE clock stopping during MPI wait states 

BitDl MCLKSTOP 

1 = MCLKO stopped (MCLKl operates at 12.5MHz) 

Bit DO MCLK12 

0 = MCLKO and MCLKl are 25MHz 
1 = MCLKO and MCLKl are 12.5MHz 


69 




Interrupt Control Registers 


Interrupts Pending 

This register may be read to determine which of the interrupts are pending at any given time. 
Interrupt Polarity 

This register is used to specify the polarity level for the external interrupts. Bits corresponding to the 
internally generated interrupts are ignored and read as zero. A bit clear^ to zero specifies an active 
low interrupt, a bit set to one specifies an active high interrupt. The register pow^ up as zero. 

Interrupt Enable 

This register is used to specify the interrupts which may interrupt the host Clearing a bit to zero 
masks the corresponding interrupt level. A bit set to a one enables the corresponding level. All bits 
power up as zero. 

Interrupt Acknovriedge 

Ibis register is used to acknowledge the internally generated interrupt sources. It has no effect on the 
external interrupt sources except for IRQ9. It is write-only and a bit is set to acknowledge the corre¬ 
sponding interrupt. For the counter timers the interrupt will not occur again until the count transitions 
to zero. For the FIFOs the empty, full or FCOUNT=0 interrupt will not occur again until the transition 
to that condition htqrpens again. 

The interrupt control registers are organized as shown in Figure 3-10. Each of the interrupt request 
sources is assigned to the same bit in each of the control registers. 


IS 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 


Interrupt Pending 

oxoo6ooooso 


Interrupt PoLuity 
0D0000S8 


OxOOD 


Interrupt Enable 
0x000000060 


Interrupt Acknowledge 
0x000000068 


IRQ9 IRQ8 CTO CTl KBO IRQ7 IRQ6 IRQ5 IRQ4 IRQ3 IRQ2 

Figure 5-10 Interrupt Connx)l Registers 
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Bit 15 

IRQ9-CMU 

Bit 14 

IRQ8 - Lx)w Power Warning 

Bit 13 

CTO - Counter Timer 0 

Bit 12 

CTl - Counter Timer 1 

Bit 11 

KBD - Keyboard Character Buffer 

BitlO 

IRQ? - Mouse 

Bit 9 

IRQ6 - External Serial Interface 

Bits 

IRQ5 - Modem 

Bit? 

IRQ4 - Ethernet 

Bit 6 

IRQ3 - Display Controller 

Bits 

IRQ2 - Hard Disk Interface 

Bit 4 

FIFO FULL/EMPTY 

Bits 

FIFO Operation Complete (FCOUNT = 0) 

Bit 2 

IRQl - Floppy Disk Literface 

Bitl 

IRQO - Centronics Interface 

BitO 

NULL - No Interrupt, hardwired to 0 


Serial InputfOutput Registers 


Keyboard Byte 

This register is read-only, it contains data from the serial input port which is used to communicate 
with the microcontroller (see Ch^to’ 6). Up to three bytes are buffered in the MPI and the program¬ 
mer is responsible for ensuring there is no overflow. A write to this register has no effect. 

Note that Mousekey information passes via the Keyboard byte. 

Keyboard Status 

This register provides a single bit (Bit DO) that is ass^ted when there is valid data in the data register. 
It is cleared on a data read operation to the KBDSTATUS register. If there is further data to be read it 
is reasserted when that data is in the KBDDATA register. 

Transmit Byte 

TTiis register is a write only 8-bit register; a read will return undefined data. Data may be written to 
this register when the TXBUSY status bit is not asserted. 

Transmit Status 

This register provides a single bit (Bit DO) that is asserted when the transmitter is busy. 




Software Reset Register 


Bit 4 RESET 

Reinitializes the MPI, clears FIFO and sets all I/O bits to default levels - same effect as Power On 
Reset 

Bit 3 lORESET 

Asserts PRST line for 2|xs 

Bit 2 FIFOSTOP 

Terminates any FIFO activity, resets FCOUNT and FSTART 

Bit 1 TSTl 

Test vectors - must be left at 0 

BitO TST2 

Test vectors - must be left at 0 


7 6 5 4 3 2 1 0 



Figure 5-11 Software Reset Register 




Error Status Register 


This register provides the cause of an Mbus error generated by an access to the MPI ASIC. A read to 
this register clears the register bit latches. 


Bit 5 

BTO 

Bit 4 

TYPE 

Bits 

SIZE 

Bit 2 

FNHD 

Bitl 

PFERR 

BitO 

MFERR 


MBus timeout 
Invalid MBus Type Field 
Invalid MBus Size Field 
FIFO No Host Data Error 
Pbus FIFO Setup Error 
Mbus FIFO Setup Error 


7 6 5 4 3 2 1 0 



Figure 5-12 Error Status Register 
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CHAPTER SIX 

J MICROCONTROLLER SUBSYSTEM 

Software monitoring of battery condition, keyboard input, and control of screen brightness and 
J contrast are controlled by a d^cated miciocontroU^. This offloads these tasks from the main CPU, 

allowing its processing power to be concentrated on running applications. 



75 


























The microcontroller performs the following functions: 

• Keyboard interfacing 

• Mousekey interfacing 

• Power supply monitoring 

■ Controlling the Status LEDs 

• System temperature monitoring 

• Screen brightness and contrast control 

• System EEPROM interfacing 

• Hardware reset control 

The microcontroller interfaces with the CPU (or host) via the serial interface of the MPI (see Ch^ter 
5). During normal operation, the microcontroU^ performs keyboard and Mous^ey scanning and 
monitors the powa supply. On receipt of a command from the host or user command from the 
keyboard it p^orms a numb^ of additional functions. 

Note: the host and microcontrdile' exchange characters which rqjiesent hexadecimal numbers. In this 
manual, hexadecimal numbers are shown with the prefix Ox. The charactm Ox do not form part of the 
command code or die data returned. 


KEYBOARD INTERFACE 


The microcontroller int^aces to the keyboard via a Honeywell 38010S keyboard scanner. This 
periodically scans the keyboard to detect key press events, and passes the soialized characto* codes 
for any depressed keys to the microcontroller. The microcontroUa' in turn interprets charactos 
received and acts upon any that represent microcontroller commands, and conveys all othos to the 
host via the saial port of the MPI (see Chtqiter S). 


Key Repeat 


The microcontroller provides a software programmable key repeat function which produces multiple 
characters while a key remains dqiressed. Key depressicm and release are registered. A key press 
causes an a character code to be returned to the host, and key release causes the same code charKter 
to be returned but with the top bit (bit 8) set Thus, if the code 0x33 is returned when a key is pressed, 
0xB3 is returned when it is released. 









The key repeat rate is specified by two parameters: the time until repeat and the time between repeats. 
These are programmable via a host command and are both measured in units of 10ms. The time until 
repeat is the time from when a key is pressed until it starts to repeat. Once repeat has started, the key 
code of the last key pressed will be presented to the host every time-between-repeats x 10ms. 


Special Characters 


Certain character combinations are intercepted by the microcontroller and used to activate keyboard 
enetered user commands. These are as follow: 

• Display Brightness Control 
ALT and UP or DOWN tf^ether 

• Display Contrast Ctmtrol 

ALT and LEFT or RIGHT together 

• Reset Control 

ALT and ESC and R together 

Only the ALT depression and release codes are sent to the host during these sequences. The (itera¬ 
tions performed by these sequences are repeated at a rate determined by the current key repeat param¬ 
eters. 


Special Routines 


Brightness Control 

The brightness of the in-built LCD display is controlled with a digital potentiometer. This is a device 
which contains a software controllable variable resistance, providing 99 (dec) steps. 

The UP cursor key pressed simultaneously with the ALT key increases the brighmess (decreases the 
Brighmess digital potentiometer value). If the key continues to be depressed the brightness continues 
to be changed until the end of track is reached. 

The DOWN cursor key decreases the brightness (increases the pot value) 

Contrast Control 

A similar digital potentiometer controls the brightness of the in-built LCD display. This facility 
functions in a similar manner to the Brighmess Control. 



Reset Control 

If a reset command from the keyboard is detected, the Power Supply Status bit is set to a 1 (indicating 
a user initiated reset) and the System Reset Line is asserted Low for 100ms. This causes a system 
reset. 


MOUSEKEY INTERFACING 


The Mousekey contains four force sensitive resistors (FSR); two are used to control vertical cursor 
movement, and two are to used to control horizontal movement. The Mousekey is isolated from the 
rest of the keyoaid and is scanned separately via four channels of an LTC1093 combined data 
aquisition and analogue to digital converter (ADC) chip. Each of the four channels is assigned one 
FSR. The pressures exerted on a each resistor is measured in terms of a voltage and converted to a 
binary value by the ADC. 

When the Mousekey left hand edge is pressed, for example, pressure is increased on the left FSR and 
reduced on the right FSR. The microcontroller calculates the difference between the voltages meas¬ 
ured across the two FSRs and uses the result to determine magnitude and direction of any cursor 
movement. 


Mousekey Initialization 


At system initialization, the Mousekey is calibrated by reading FSR voltages and storing them in 
variables within the microcontroller memory. When the Mousekey is subsequently scanned, any 
voltages that differ from these calibration values are demed to be an indication of Mousdrey pres¬ 
sure. The algorithm for converting left, right, up and down voltages into mouse movements is shown 
below. 

Read voltage on left FSR 

Read voltage on right FSR 

Calculate the difference (Vright - Vleft) 

If result is 0 - no horizontal motion requested 

If result is positive a net right motion has been requested. 

Return this as a positive X motion. 

If result is negative a net left motion has been requested 
Return this as a negative X motion. 




Vertical movements are calculated in a similar way and returned as positive or negative Y motions 
respectively. TTie algorithm evaluates relative voltages to counteract drift in the steady state FSR 
values due to thermal effects. 


Mousekey Events 


The microcontroller passes mouse events to the host as a sequence of four bytes, OxFD OxSS OxXX 
OxYY. The first byte, OxFD, indicates to the host that three mouse event bytes are to follow. The 
next, OxSS, provides the foUowing status information: 


Bit? 

Y data overflow (always 0) 
1 = overflow 

Bit 6 

X data overflow (always 0) 
1 = overflow 

Bits 

Y data sign 

1 = negative Y motion 

Bit 4 

X data sign 

1 = negative X motion 

Bits 

Event Rag 

Bit 2 

Middle button status 

1 = depressed 

Bitl 

Right button status 

1 = depressed 

BitO 

Left button status 

1 = depressed 


The OxXX and OxYY bytes represent the magnitude of the X and Y motions recorded in a particular 
mouse event The force on the Mousekey is represented by 3 bits, so the values of OxXX and OxYY 
ranges from 0x00 to 0x07. These values caruiot overflow, so the X and Y data overflow bits will 
always be 0. 

Mouse Buttons 

The buttons found on a conventional three button mouse are simulated using special key combinations 
on the keyboard. Mouse button events are detected by the keyboard scanning routine, which is always 
executed immediately before the Mousekey scanning routine. During system initialization, the Event 
Flag is cleared to 0. If the keyboard scanning routine detects a mouse button event, it sets the associ¬ 
ated button bits, and sets the Event Flag to indicate that the status has changed and a mouse event 
packet should be sent to the host. 
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Cursor Movement Requests 

After the keyboard scanning routine is complete, the mouse scan routine is called. It determines if a 
net motion has been detected and if so, fills in the sign bits, X and Y data fields and sets the Event 
Flag (it may already have been set by the keyboard scanning routine) to indicate a changed status. 

At the end of the Mousekey scanning routine, the Event Flag is checked to see if it has been set. If it 
has, a mouse event packet is sent to the host and the reserved bit is cleared. 

Mouse Event Parameters 

Mouse operation is controlled by two parameters: the force on the Mousekey, and the time between 
successive calls to the mouse scan routine. Key pressure is quantized into eight levels, so that a light 
key pressure moves the cursor in steps of one unit every time the mouse scan routine is called, and the 
heaviest measureable key pressure causes the cursor to move in steps of 8 units every time the mouse 
scan routine is called. The result of this is that increasing the pressure on the Mousdcey accelerates 
cursor motion. 

Mouse scan rate is variable in units of 10ms and determines how fast the mouse moves when a 
constant pressure is ^plied to the Mousekey. This rate is software programmable and is stored in 
EEPROM to maintain its value during system power down. 


HARDWARE INTERFACES 


The microcontroller communcates with the host via serial port of the MPI. It provides control, data 
aquisition and status aquisition via four ports, each with eight 1-bit lAi) ports. These are assigned as 
shown in Table 6-1 


Host Instruction Protocol 


The microcontroller incoiporates a mask programmable read-only memory which contains the 
complete microcontroller firmware. The host may make various requests to the microcontrollCT via 
the serial port of the MPI. The microcontroller receives and interprets these requests and takes the 
appropriate action. It returns values (if required) to the host as characters. 

The microcontroller issues the code OxFE to acknowledge all host instructions, followed by one or 
more bytes as required to fulfill the request before resuming normal keyboard and Mousdcey scan¬ 
ning. 

Table 6-2 outlines the request codes available to the host and the responses from the microcontroller. 
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BIT-PORT 

DIRECTION 

FUNCTION 

Port0(0) 

Output 

Keyboard Scanner Reset 

PortO(l) 

Ou^ut 

Keyboard Scanner Clock 

Pon0(2) 

Input 

Keyboard Data 

Port0(3) 

Input 

DC Level OK 

Port0(4) 

Input 

Battery Level 1 

Port0(5) 

Input 

Battery Level 2 

Port0(6) 

Input 

Battery On 

Port0(7) 

Input 

Battery Full 

Portl(0) 

Output 

Parity Detect Enable 

Portl(l) 

Ou^t 

Parity Error Inject 

Portl(2) 

- 

Reserved 

Poitl(3) 

- 

Not Used 

Portl(4) 

- 

Not Used 

Portl(5) 

- 

Not Used 

Portl(6) 

Input 

Floppy Disk Density Status 

Portl(7) 

Input 

Roppy Disk Ready Status 

Port2(0) 

Output 

Bit I/O Device Control 1 

Port2(l) 

Output 

Bit I/O Device Control 2 

Port2(2) 

Output 

Brighuiess Chip Select 

Port2(3) 

Ou^ut 

Contrast Chip Select 

Port2(4) 

Output 

ADC Chip Select 

Port2(5) 

Ou^ut 

EEPROM Chip Select 

Port2(6) 

Output 

Temperature Sense Read Data 

Port2(7) 

Output 

EEPROM Read Data 

Port3(0) 

Input 

Serial Data From MPI 

Port3(l) 

Output 

Serial Data to MPI 

Port3(2) 

Ou^ut 

System Reset 

Port3(3) 

Ou^ut 

Sound Beeper 

Port3(4) 

Ou^ut 

Battery low LED 

Port3(5) 

Ou^ut 

User LED 

Port3(6) 

Ou^ut 

External LED 

Port3(7) 

Output 

Interrupt CPU on Level 14 


Table 6-1 Bit-Port Assignment 




REQUEST 

MEANING 

VALUE RETURNED (after OxFE) 

System Information 

0x10 

Read Ethernet Address 

3bytes with Net Address. 

For example, for address 0x0044FA the bytes 
returned would be 0x00,0x44, OxFA 

0x11 

Read Hardware Revision 

2bytes with Hardware Revision Major and Minor. 
For example Rev 1.3 is returned as 0x01,0x03 

0x12 

Read Controller Firmware Rev 

Format as for Hardware Revision 

This data is hardwired into the microcontroll^ 
firmware 

0x13 

Read System MAXTEMP 

Value in degrees centigrade hexadecimal 

Eg 25 degrees is returned as 0x19. 

0x14 

Read System MINTEMP 

As for MAXTEMP 

0x15 

Read Temperature Sensor ADC 

As for MINTEMP 

0x16 

Read POWERCOUNT 

2bytes, most significant first, giving the number of 
times the SPARCbook has been powered. 

0x17 

Read POWERONSECONDS 

4bytes seconds SPARCbook has been powered 

0x18 

Return Microcontroller Status 

Returned byte 

Bit 7 Bad Checksum 

Bit 6 Diagnostics Fail 

Bit 5 Watchdog Reset (l=Watchdog Reset) 

Bit 4 User Reset bit (0=POR) 

Bit 3 Battery Full bit 

Bit 2 Battery On bit 

Bit 1 Battery Level 2 

Bit 0 Battery Level 1 

0x19 OxNN 

Read ADC channel OxNN 

2 bytes containing 10-bit value. 

First byte contains most significant 8 bits, second 
byte contains least significant 2 bits 
i.e. bbbbbbbb OOOOOObb 

CH OxNN FUNCTION 

0 0x00 Force sensitive resistor 0 

1 0x01 Force sensitive resistor 1 

2 0x04 Force sensitive resistor 2 

3 0x05 Force sensitive resistor 3 

4 0x02 Battery Voltage sensor 

5 0x03 Temperature sensor 
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REQUEST 

MEANING 

VALUE RETURNED 

Commands 

0x20 

Turn USER LED off 

None 

0x21 

Turn USER LED on 

None 

0x22 OxNN 

Sound Beeper for OxNN increments of 10ms 

None 

0x23 OxNN 

Increment Brightness OxNN times (0 - 63 hex) 

None 

0x24 OxNN 

Decrement Brightness OxNN times (0 - 63 hex) 

None 

0x25 OxNN 

Increment Contrast OxNN times (0 - 63 hex) 

None 

0x26 OxNN 

Decrement Contrast OxNN times (0 - 63 hex) 

None 

0x27 OxNN 

Read EEPROM register OxNN 

16-bit register Value 

0x28 OxNN OxXXOxYY 

Write EEPROM registo* OxNN with data OxXXYY 

None 

0x29 OxMM OxNN 

Rollover parameters 

MM is initial delay in 10ms increments, OxNN is 
the interval between characters in 10ms increments. 
Default is 400ms and 10 chars/sec. 

None 

0x2A0xNN 

Mouse scan period in units of 10ms 

None 

0x2B0xNN 

Write byte OxNN to microcontroller port 1 ^ 

None 

0x2C0xNN 

Read pin values from microcontroller port 1 

1-byte port value 

Miscellaneous 

0x30 

Acknowledge Interrupt 

None 

0x40 

Enable Watchdog 

(if watchdog commands are not received at least 1 
per second the system will be reset) 

None 

0x41 

Disable Watchdog (default) 

None 

0x42 

Watchdog command 

None 


Table 6-2 Host Instructions and Replies 
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Host Interrupts p 

If either of the battery low signals is detected low, or the external power suiq)ly is plugged in or 
removed, the host is interrupted on Level 14 by setting the Interrupt Host port bit. The port bit remains p 

set until an interrupt acknowledge is received from the host. It is returned to its default zero condi¬ 
tion. The host is able to read the Microcontroller Status Byte to determine the cause of the interrupt 
and then take the appropriate action. 

EEPROM Data 

The following data is defined in the EEPROM. This is a 1024bit device treated as 128 byte locations; 

Note that bytes 0-31 may be not written, they are resm^ed for manufacturing information. r- 

n 
n 


BYTE 

FUNCTION 

COMMENT 

0 

Ethernet Address (serial no) low byte 


1 

Ethernet Address (serial no) middle byte 


2 

Ethernet Address (serial no) high byte 


3 

HW Revision - Minor Level 


4 

HW Revision - Major Level 


5-14 

RESERVED for hardware use 


15 

Byte Checksum for bytes 0-14 


16 

MAXTEMP in degrees C 


17 

MINTEMP in degrees C 


18 

POWERCOUNTbyteO 

No of power up cycles 

19 

POWERCOUNT byte 1 


20 

POWERONSECONDS byte 0 

No of power on secs 

21 

POWERONSECONDS byte 1 


22 

POWERONSECONDS byte 2 


23 

POWERONSECONDS byte 3 


24 

Keyboard time until repeat 

lOms units 

25 

Keyboard time between repeats 

10ms units 

26 

Time between Mouse scans 

10ms units 

27-31 

RESERVED for system use 

Access code protected 

31-63 

RESERVED for system use 

No Access code needed 

64-127 

RESERVED for application use 

No Access code needed 


Table 6-3 EEPROM Address Map 
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CHAPTER SEVEN 

UNIVERSAL PERIPHERAL CONTROLLER 


One of the devices implemented in the SPARGxwk design to achieve its high level of integration is 
the 82C710 Universal Peripheral Controller (UPC) from Chips and Technologies Inc. This single 
chip provides the SPARCbmk with the following facilities: 

• Floppy disk ctmtroller 

• IDE Hard disk interface 

• Parallel Centronics interface 

• Serial Port 

• Mouse Interface 


Floppy Diric 
CoHroller 


Host Bus 
Interface 
and 

Confignxatian 

Reguten 


PatsUel 

Asynchronous 

Mouse 

Hard Disk 

Port 

Serial Port 

Port 

CantroUer 



Floppy Disk Drive 
(not Gtted in dual hard disk ntodels) 






Y//// /A 




Figure 7-1 UPC Pmpheral Control Architecture 































FLOPPY DISK CONTROLLER 


The UPC contains a floppy disk controller (FDQ fully compatible with the NEC pPD72065B. An 
integral 48mA floppy interface buffer allows the disk drive to connect directly to the UPC. The 
SPARCbook is equipped with one 3.S" floppy disk drive in single hard disk models, but does not 
contain a floppy disk drive in dual hard disk models. 


Host Interface 


The activities of the FDC are controlled via a set of four register locations, shown in Table 7-1. 

Digital Output Register 

This is a write-only register which provides drive select 0)its 1:0 = OObin), motor enable (bit 4 = 1), 
DMA enable (bit 3 = 1) and reset control (bit 2=1). 

Main Status Register 

This is an 8-bit register which contains information about current activity by the FDC. 

Data Register 

The data register is used by the host to issue instructions to the FDC, and by the FDC to return status 
information to the host The FDC automatically directs information to or from the api^opriate internal 
location. 

Data Rate Register 

The lower two bits in this register are used to select the data rate for the FE)C. OObin selects a 
SOOKbyte/s data rate. 

Digital Input Register 

Only bit 7 in this register is used for FDC operations. It provides the complement of the Disk Change 
input pin. 


ADDRESS 

REGISTER 

ACCESS 

OxOOCC003FO 

Unused 


0x00CC003Fl 

Unused 


OxOOCC003F2 

Digital Output Register 

W 

OxOOCC003F3 

Unused 


0x00CC003F4 

Main Status Register 

R 

OxO0CC0O3F5 

Data Register 

R/W 

0x00CC003F6 

Unused 


0x00CC003F7 

Data Rate Select Register 

W 


Digital Input Register 

R 


Table 7-1 FDC Register Map 


86 




Floppy Disk Commands 


The host controls the FDC with commands written via the Data Register at OxOOCC(X)3F5. There are 
seventeen commands available which are initiated by a multi-byte write to the data register. The first 
byte contains an operation code, and this is followed by a number of bytes containing parameter 
information (the number of parameter bytes depends upon the instruction). Most commands to the 
FDC entail a three part sequence consisting of the Command Phase, the Execution Phase and the 
Result Phase. 

Command Phase 

During the command phase, the host writes an instruction byte togetter with the parameters required 
to carry out the instruction via the Data Register. The FDC automatically determines number of 
parameters required with the command byte and the order in which they should be supplied by the 
host 

Execution Phase 

During the execution phase, the FDC acts upcm the command supplied during the command phase. 
Result Phase 

After execution of an instruction, the FDC automatically presents status information for the host to 
read from the Data Register. The status infcxmation supplied varies according to the action carried 
out 


Figure 7-2 summarizes the command set of the FDC. The bytes written during the command phase 
are shown within shaded areas, next to the bytes read by the host during the associated result phase. 


Key to abbreviations used in Figure 7-2: 

c 

Cylinder 

HD 

Selected head 

NCN 

New cylinder number 

D 

Data pattern 

HLT 

Head load time 

R 

Record 

DTL 

Dau length 

HUT 

Head unload time 

R/W 

Read/Write 

EOT 

End of track 

MF 

FM/MFM mode 

SC 

Sectors per cylinder 

GPL 

Gap 3 length 

MT 

Multi-track 

SK 

Skip 

H 

Head Number 

N 

Bytes per sector 

SRT 

Step rate time 

STP 

Scan step 



ST0,1,2,3 

Status registers 0, L 2,3 

USO. 1 

Selected drive number 













Result Phase 


INVALID CODE 


Figure 7-1FDC Instruction Summary 

































































FDC Operating Modes 


ITie FDC in the SPARCbook application only ever controls a single 3.5" floppy disk drive. The FDC 
reads and write SunOS format disks, which can be either high density 1.4Mbyte disks or low density 
720Kbyte disks. 

Table 7-2 summarizes the disk types supported by the SPARCbook and the parameters required to 
configure the FDC to correctly carry out commands. 


PARAMETER 

HIGH DENSITY 

LOW DENSITY 

UNIT 

Step Rate 

3 

3 

ms 

Head Unload Time 

64 

64 

ms 

Head Load Time 

12 

12 

ms 

Gap 3 Lengtht 

0x24 

0x2A 

bytes 

Gap 3 Lengthtt 

0x6D 

0x50 

bytes 

Filler (format pattern) 

0xE5 

0xE5 

- 

Number of Cylinders 

80 

80 


Sectors/track 

18 

9 

- 

Sector Size 

512 

512 

bytes 

Surfaces 

2 

2 


Data Encoding Mode 

MFM 

MFM 


t Gap 3 for read and write commands 
tt Gap3 for format command 


Table 7-2 Hoppy Disk Parameters 


IDE HARD DISK INTERFACE 


The UPC i»ovides an interface controller capable of supporting two hard disk drives with Integrated 
Drive Electronics (IDE) int^aces. The UPC also provides control of external 16-bit data buffers. 


IDE Overview 


IDE hard disk drives incorporate an integral controller which interprets control signals and commands 
from the host, and reads data from and writes data to the disk surfaces. 

IDE drives are able to support applications in PC/XT and PC/AT environments. The SPARCbook 
only suf^rts drives conflgured for PC/AT compatibility. One or two drives may be present, but in a 
two drive system, the drives must be electrically configured as primary and secondary drives. Refer¬ 
ence should be made to the technical literature supplied with the disk drive for information about drive 
configuration. 
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IDE Interface Operating Modes 


TTie UPC provides two IDE interface modes: the AT mode, used in the SPARCbook and the XT 
mode. The mode is configured via bit 6 of the UPC Configuration Register at OxOC. When this bit is 
at ‘ r, the AT mode is selected. 

The UPC IDE interface control registers are accessible in the 8-bit I/O region of the SPARCbodc 
memory map, and the data register is accessible within the 16-bit I/O region of the MPI’s Pbus 
address map. This results in the address Inactions of the IDE Task FUe Registers shown in Table 7-3. 
Transfers between hard disk sectors and the SPARCbook main memory take place via the MPI (see 
Chapter 5). The hard disk int^ace uses polled operations only, DMA operations are not supported. 


Task FUe Registers 


The activities of an IDE hard disk drive are controlled via a set of register locations within the integral 
drive controller called Task File Registers. The UPC decodes host accesses to these registers. Table 
7-3 lists the task file registers 


ADDRESS 

REGISTER 

ACCESS 

Ox00C8001FO 

Data Register 

R/W 

OxOOCCOOlFl 

Error Register 

R 

OxOOCC001F2 

Sector Count 

R/W 

0x00CC0OlF3 

Sector Number 

R/W 

OxOOCC001F4 

Cylinder Low 

R/W 

OxOOCCOOlFS 

Cylinder High 

R/W 

OxOOCC001F6 

Drive/Head 

R/W 

OxOOCCOOlF? 

Status Register 

R 


Command Register 

W 

0x00CC003F6 

Alt Status Register 

R 


Fixed Disk Register 

W 

0x00CC003F7 

Digital Input Register 

R 


Table 7-3 Task File Registers 
Data Register 

The data register is the register through which all data is passed on read and write commands. All 
data transfers are 16-bits with the exception of the ECC bytes transferred during Read or Write Long 
commands. Data is stored on the disk least significant byte first, then most significant byte. 

Error Register 

This read-only register contains the status of the last executed command. 

Sector Count Register 

This register contains the number of sectors to be read or written during a Vmfy, Read, Write or 
Format command. Note that a value of 0 means a 2S6 sector transfer. 
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Sector Number Register 

This register contains the starting sector number for Read, Write and Verify commands. 

Cylinder Number Registers 

Tbese registers contain the LSB and MSB of the first cylinder number where the disk is to be accessed 
for Read, Write, Seek and Verify commands. 

Drive/Head Register 

This register contains the drive and head select bits; 

Bit 4 Drive select 

0 = Primary 
1 = Secondary 
Bit 3:0 Head number 

Status Register 

This register contains status infromation for the drive and controller. The contents of this register are 
updated at the completion of each command. Pending interrupts are cleared whenever this register is 
read by the host. 


Bit 7 Busy 

Bit 6 Ready for command 

Bit 5 Fault 

Bit 4 Seek command completed 

Bit 3 Ready to transfer data 

Bit 2 Data correction sucessful 

Bit 1 Index mark detected 

Bit 0 Error from last command 


Command Register 

This register is used to pass commands to the hard disk. The commands consist of an 8-bit command 
code. Execution begins immediately after this registo* is written. Table 7-4 shows a summary of the 
executable commands and the parameters used. 

Alternate Status Register 

This register contains the same information as the Status Register. The difference is that reading the 
alternate status register will not clear pending interrupts. 

Fixed Disk Register 

This register contains interrupt enable and reset control bits. Bit 3 when set holds the drive in a reset 
state. If two drives are present, the second drive will be reset as well. Bit 2 when clear enables 
interrupts from the hard disk drives. 

Digital Input Register 

This register loops back the drive select and head select of the currently selected drive. Bit 7 of this 
register is used by the FDC and has no relevence to the IDE interface. 
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I 


COMMAND NAME 

CODE 

(hex) 

PARAMETERS USED 

SC SN CY SDH 

Recalibrate 

lx 

n 

n 

n 

D 

Read Sector (retry) 

20 

y 

y 

y 

y 

Read Sector (no retry) 

21 

y 

y 

y 

y 

Read Sector Long (retry) 

22 

y 

y 

y 

y 

Read Sector Long (no retry) 

23 

y 

y 

y 

y 

Write Sector (retry) 

30 

y 

y 

y 

y 

Write Sector (no retry) 

31 

y 

y 

y 

y 

Write Sector Long (retry) 

32 

y 

y 

y 

y 

Write Sector Long (no retry) 

33 

y 

y 

y 

y 

Read Verify Sector (retry) 

40 

y 

y 

y 

y 

Read Verify Sector (no retry) 

41 

y 

y 

y 

y 

Format Track 

50 

n 

n 

y 

y 

Seek 

7x 

n 

n 

y 

y 

Drive Diagnostics 

90 

n 

n 

n 

n 

Initialize Drive Parameters 

91 

y 

n 

n 

y 

Read Sector Buffer 

E4 

n 

n 

n 

d 

Write Sector Buffer 

E8 

n 

n 

n 

d 

Identify Drive 

EC 

n 

n 

n 

d 

Power Management 

F8-FD 





Key: 

SC = Sector Count Register; SN = i 
Registo*; y = Parameter is used; n = 

sector number Register; CY = Cylinder Regist^; SDH = Drive Head 
= Parameter not used; D = drive parameter only; x = Dont care 


Table 7-4 AT Command Summary 


IDE Command Summary 


Recalibrate 

This command moves the heads to cylinder 0. On receipt of this command, the drive sets BSY and 
moves the heads to cylinder 0. The drive waits for the sed: to complete before updating its status, 
resetting BSY, and generating an interrupt. If the drive cannot reach cylinder 0, it sets both the 
“ERR” bit in the Status register and the ‘TKO” bit in the Error register. An aborted command 
response will be given if the drive is not ready. When the command completes successfully, the Task 
File registers will be affected as follows; 


Cylinder High 

00 

Cylinder Low 

00 

Error 

00 

SDH 

Unchanged 

Sector Count 

Unchanged 

Sector Number 

Unchanged 



n 


n 

n 
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Read Sector 

Tliis command reads from 1 to 256 sectors, as specified in the Task File, beginning at the specified 
sector. A sector count of 0 requests 256 sectors. As soon as the Command register is written, the drive 
sets BSY and begins execution of the command. An ID not found error is returned if incorrect task 
file parameters are passed. If the drive is not already on the desired track, a seek is initiated. When 
the sector ID is located, the DRQ bit is set, and an int^rupt is generated. 

The DRQ bit is always set, regardless of the presence or absence of an error condition at the end of a 
sector. When the command completes successfuUy, the Task File register contains the cyclinder, 
head, and sector number of the last sector read. The sector count is zero after successful execution of 
the command. 

Multiple sector reads set DRQ and generate an interrupt at the completion of each sector. DRQ is 
reset and BSY is set immediately when the Host completes reading the sector. If an «Tor occurs 
during a multiple sector read, it will terminate after the sector in error is transferred to the host. The 
Task File indicates the location of the sector where the error occurred. The Host may then read the 
Task File to determine what error has occured, and on which sector. If no mor is detected, the 
cylinder, head, and sector registers are updated to point to the next sequential sector. 

Read Long 

Hie Read Long command performs similarly to the Read Sectors command, except that it returns the 
data and the ECC bytes contained in the data field of the desired sector. During a Read Long com¬ 
mand, the drive does not check the ECC bytes to determine if there has been a data error. Only single 
sector Read Long operations are suj^rted. Data transfers are 16bits wide and ECC byte transf^ are 
Sbits wide. 

Write Sector 

This command writes up to 256 sectors, as specified in the Task File, beginning at the specified sector. 
As soon as the Command regist^ is written, the drive waits for the Host to fill the sector buffer with 
the data. Hiere is no interrupt gen^ted to start the first buffer fill operation. Once the buffer is full, 
the drive sets BSY and begins command execution. 

An ID not found error is returned if incmrect task file parameters are passed. If the drive is not 
already on the desired track, an implied sedr is performed. Once at the desired track, the drive locates 
the appropriate ID field and writes data from the buffer, plus 7 bytes of ECC. Upon command 
completion, the Task File registers contain the cylinder, head, and sector number of the last sector 
written. The sector count is zero after successful executirm of the command. 

Multiple sector writes set DRQ and gen^te an interrupt each time the buff^ requites filling. DRQ is 
clear^ and BSY set immediately when the Host fills the sector buffer. If an oror occurs during a 
multiple sector write, it will terminate at the sector where the error occurs. The Task File indicates the 
location of the sector where the mor occurred. The Host may then read the Task File to determine 
which etTOT occured, and on which sector. If an mor is not detected, the cylinder, head, and sector 
registers are updated to point to the next sequential sector. 
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Write Long 

This command is identical to the Write Sectors command, except that it writes the data and ECC bytes 
directly from the sector buffer. The drive does not generate ECC for this command. Only single 
sector operations are supported. 

Read Verify 

This command functions identically to the Read Sectors command, except that no data is transferred 
to the Host. Up to 256 sectors will be read into the sector buffer and the ECC bytes are verified. 

When each sector has been verified, the Task File is updated, but no DRQ or interrupt is set until all 
sectors have been verified. A value of 0 in the sector count register indicates that 256 sectors are to be 
verified. 

Format Track 

This command formats the track specified in the Task File. Once command registers have been 
written, the drive waits for the host to fill the buffer with 512 bytes of format data. After the data is 
written to the data register, the drive analyzes the information for each sector and performs the 
requested action for each sector. Upon command completion, the drive places status information in 
the Task File and signal an IRQ to the host 

The 512 bytes of data in the sector buffer must consist of 2 bytes for each sector to be formatted. The 
most significant byte of each word designates the sector to be formatted. The least significant byte 
contains a descriptor indicating which action should be carried out with that sector as follows: 

0x00 Format Sector Good 

0x80 Format Sector Bad 

0x40 Assign Sector to Alternate 

0x20 Unassign Alternate Location for this Sector 

Seek 

This command initiates a seek to the track and selects the head specified in the Task File. The drive 
need not be formatted for a seek to execute prcqierly. When the command is issued, the drive sets 
BSY, initiates the seek, clears BSY, and generates an interrupt Only the Cylinder register is valid for 
this command. The drive does not wait for the seek to complete before returning the interrupt Seek 
complete (DSC) will be set upon completion of the command. If a new command is issued while a 
seek is in progress, the drive will wait with BSY active, until the seek is complete before starting the 
new command. No checks are made on the validity of the sector number. The ERR bit in the Status 
register and the IDNF bit in the Error register will be set if an illegal cylinder number is specified. 




Initialize Drive Parameters 

This command enables the host to set the head switch and cylinder increment points for multiple 
sector operations. In translate mode, the logical head, sector, and cylinder numbers in the Task File 
will be translated to their native physical values in the Task File. They are not checked to validity by 
this command, therefore if they are invalid, no error will be rqx)rted until an illegal access is made by 
some other command. Upon receipt of the command, the drive sets BSY, saves the parameters, resets 
BSY, and generates an interrupt 

Read Buffer 

This command allows the host to read the current contents of the drive’s sector buffer. When this 
command is issued, the drive sets BSY, sets up the sector buffer to a read operation, sets DRQ, clears 
BSY, and generates an interrupt The host then reads up to S12bytes of data from the buffer. 

Write Buffer 

This command allows the host to overwrite the contents of the drive’s sector buffer with any data 
pattern desired. Only the command register is valid for this command. When this command is issued, 
the drive will set BSY, set up the sector buffer for a write operation, set DRQ, reset BSY, and gener¬ 
ate on interrupt. The host may then write up to 512 bytes of data to the buffer. 

Identify Drive 

The Identify Drive command allows the host to obtain parameter information from the drive. When 
the command is issued, the drive sets BSY, stores the required paramet^ information in the Sector 
buffer, sets the DRQ bit, and generates an intermpt. The parameter words in the buffer are in hexa¬ 
decimal format right justifred as shown Table 7-S. 


WORD 

DESCRIPTION 

00 

A constant-0A5A 

01 

Number of fixed cylinders 

02 

Number of removable cylinders 

03 

Number of heads 

04 

Number of unformatted bytes/track 

05 

Number of unformatted bytes/sector 

06 

Number of physical sectors/track 

07 

Number of bytes in the inter-sector gaps 

08 

Number of bytes in the sync fields 

09 

Vendor Unique 

10-19 

Serial number 

20 

Buffer type 

21 

Buffer size (x 512 bytes) 

22 

Number of ECC bytes passed during read or write long commands 

23-26 

Controller frrmware revision 

27-46 

Model Number 

47 

Number of sector^nterrupts 

48 

Double word transto flag 

49-255 

Reserved 


Table 7-5 Drive Parameters 
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Power Save Commands 

In order to conserve power, these commands allow the drive to operate in modes other than fully 
operational. These are: Idle Mode, in which the driveis up to sp^ is and ready to accept a com¬ 
mand; Sleep Mode in which the drive is spun down with only the interface chip powered up; and 
Standby Mode in which the drive is spun down with all normal electronics on. 

The Power Save Commands are as follows: 

OxEO Enter Standby Mode immediately. 

OxEl Enter Idle Mode immediately. 

0xE2 Enter Standby Mode immediately. 

0xE3 Enter Idle Mode immediately. 

OxES This command allows the host to check the drive power status. If it is in Active or Power Save mode, 

the Sector Count register will be set to OxFF. If the drive is in, going to, or recovering horn 
STANDBY MODE, the Sector Count register will be set to 00. 

0xE6 Enter Sleep Mode 


PARALLEL PORT 


The Parallel Port is compatible to the IBM XT-AT Parallel Port, with a PS/2 like extended mode for 
bi-directional transit. When the parallel port is disabled via the configuration register, all outputs 
are disabled, and register contents are preserved. Upon power up, the control signals are inactive. 
The status registers reflects the status signals. 


Printer Interface Registers 


Table 7-6 shows the registers associated with the parallel printer port These are compatible with the 
IBM PC parallel port. All addresses for the parallel port are ofiset fiom the base address specified 
during the UPC configuration process. The table shows the value contained in the parallel port 
registers afto'a hardware reset. 

The parallel port registers are accessible in the SPARCbook’s 8-bit I/O region at OxOOCCOOOOO. The 
address offset of the parallel port registers is programmable via one of the UPC configuration regis¬ 
ters. Table 7-6 shows the addresses assigned by the resident firmware. 

Data Register 

Data written to this register is Uansmitted to the printer. Data read from this port is identical to that 
which was last written by the host. 







ADDRESS 

REGISTER 

ACCESS 

RESET 

0x00CC00330 

Data Register 

R/W 

DontCare 

0x00CC00331 

Status Register 

R 

0x80 

0xO0CC0O332 

Control Register 

W 

0x00 


Table 7-6 Parallel Port Registers 
Printer Status Registers 

This register contains the following status information: 

Bit? BUSY 

0 = Printer busy 
1 = Printer ready to accept data 

Bit 6 ACK. 

0 = Printer has received a character and is ready for another. 

1 = Printer not ready 

Bit 5 PE-Paper Empty 

0 = Paper OK 
1 = Paper end 

Bit 4 SLOT 

0 = Printer not selected 
1 = Printer is online 

Bits ERROR 

0 = Printer Error 
1 = No errors. 

Bits 2:0 Reserved 

Printer Control Register 

The bit definitions for this register are: 

Bit 7:6 Reserved 

Bit 5 DIR - Parallel Control Direction 

In printer mode, the direction is always out, regardless of the state of this bit. 
In the extended mode: 

0 = output 
1 = input 

Bit 4 IRQEN. 

0 = IRQ disabled 

1 = Enable IRQ when ACK changes from active to inactive 





Bit 3 SLCTIN 

0 = Printer not selected 
1 = Printer selected 

Bit 2 INTT 

0 = Start the printer (50|is pulse minimum) 

Bitl: AUTOFD 

0 = No autofeed. 

1 = Printer to generate a line feed after each line 

BitO: STROBE 

0 = No strobe 
1 = Assert STROBE 


MOUSE PORT 


The SPARCbook features an inbuilt Mousekey on the keyboard which is controlled by the 
microcontrollCT (see Chapter 6), and not the UPC. 

In addition, the UPC provides a port which appears via a 6-pin mini-DIN connector located on the 
connector panel, to which an external pointing device (such as a mouse or graphics tablet) or keyboard 
may be connected. 

Pointing devices provide the computer to which they are connected with position and button press 
information, and external keyboards provides character information. The UPC provides a serial data 
input channel and shift register to allow the host to read this information from an 8-bit data port. The 
Urc also provides a clock ouq)ut used by the external device to synchronize its communications. 

Devices connected to the mouse port must use TTL level signals and not RS232. 

Connecting RS232 devices to the mouse port may cause damage to the SPARCbook 


Mouse Port Registers 


The UPC contains two registers associated with mouse controller operations. These are accessible in 
the 8-bit I/O region at 0x00CC(X)000. The offset address for the mouse registers is programmable via 
one of the UPC configuration registers. The address used by the resident firmware is 0x310. Table 7-7 
shows the mouse port registers. 


ADDRESS 

REGISTER 

ACCESS 

OxOOCC00310 

Mouse Port Data 

R 

0x00CC00310 

Mouse Port Status/Control 

R/W 


Table 7-7 Mouse Port Registers 
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Mouse Data Port 

This location is read by the host to obtain data input by an external mouse. 
Mouse Status and Control Register 

This register contains a number of status bits and a number of control bits; 
Control Bits 


Bit? 

Mouse Clock Enable 

0 = Clock disabled 

1 = Clock enabled 

Bit 4 

Pointing Device Intmupt 

0 = Disable interrupt 

1 = Enable intorupt 

Bits 

Pointing Device Reset 

0 = Normal operation 

1 = Reset device 

Status Bits 
Bit 6 

Pointing Device Clear 

Bit 5 

Pointing Device Error 

Bit 2 

Pointing Device Transmit Idle 

Bitl 

Pointing Device Character Received 

BitO 

Pointing Device Idle 


SERIAL PORT 


The UPC incorporates a universal asynchronous receiver and transmitter (UART) which provides a 
serial interface. This appears on the connector panel via an 8-pin mini DIN connector. Buff(as 
external to the UPC convert the serial channel signals to RS232C levels. The UART allows data rates 
from 50 to 38400 Baud; a character size of 5 to 8 bits, with one start bit and 1,1.5 or 2 stqp bits; and 
the use of even, odd or no parity. 


Serial Port Registers 


The UPC contains eleven registers associated with UART operations. These are accessible in the 
Pbus 8-bit I/O region at OxOOCCOOOOO. The offset address for the UART registers is programmable 
via one of the UPC configuration registers. The address used by the resident firmware is 0x3F8. Table 
7-8 shows the UART port registers. 



Access to the Transmit and Receive buffers, to the Interrupt Enable register and Divisor register is 
controlled by bit 7 of the Byte Format register. 


ADDRESS 

REGISTER 

Byte Format Register Bit 7 = 0 

0x00CC003F8 

Receive Buffer/Transmit Buffer 

0x00CC003F9 

Interrupt Enable Register 

Byte Format Register Bit 7 = 1 

0x00CC003F8 

Baud Rate Divisor LSB 

0x00CC(X)3F9 

_ 

Baud Rate Divisor MSB 

Byte Format Register Bit 7 = x 

0x00CC003FA 

Interrupt Flag Register 

OxOOCC003FB 

Byte Format Register 

0x00CC003FC 

Modem Control Register 

OxOOCC003FD 

Line Status Register 

OxOOCC003FE 

Modem Status Register 

0x00CC003FF 

Scratch Pad Register 


Table 7-8 UPC Serial Port Registers 
Transmit and Receive Buffers 

A read from this location returns data received from the serial port A write is used to load a byte for 
transmission. 

Interrupt Enable Register 

This register controls the enabling of four UART interrupt sources. 

Bits 7:4 Reserved 

Bit 3 Modem Status Interrupts 

0 = Interrupts disabled 

1 = Interrupt when Modem Register bits change state 

Bit 2 Error Status Interrupts 

0 = Interrupts disabled 
1 = Interrupt on error 

Bit 1 Transmit Buffer Interrupt 

0 = Interrupt disabled 
1 = Interrupt on Transmit Buffer empty 

Bit 0 Receive Buffer Interrupt 

0 = Interrupt disabled 

1 = Interrupt when Receive Buffer contains valid data 
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Interrupt Flag Register 

This register identifies the highest pending interrupt. It can be read to determine the source of a UART 
interrupt. 

Bits 7:0 Reserved 

Bits 2:1 Interrupt Source 

11= Error Interrupt - highest priority 
10 = Receive Buffer Full 
01 = Transmit Buffer Empty 
00 = Modem Status 

Bit 0 Interrupt Flag 

0 = Valid interrupt pending 
1 = No interrupts pending 

Byte Format Register 

This register is used to select the character length, number of stop bits, parity control and break 
control. It also contains a bit which controls host access to the Divisor registers. 

Bit 7 Divisor register address bit 

0 = No host access to divisor registers 
1 = host access to divisor registers 

Bit 6 Break control 

1 = Force TxD pin to logic 0 (break condition) 

0 = TxD pin normal operation 

Bit 5 Force Parity 

0 = Force Parity Disabled 
1 = Force Parity Enabled 

Bit 4 Parity Sense 

0 = Odd Parity 
1 = Even Parity 

Bit 3 Parity Enable 

0 = no parity generation or checking 
1 = Parity generation and checking enabled 

Bit 2 Stop Bits 

0=1 Stop bit 

1 = 1.5 if character length is 5 bits 

2 bits if word length is 6,7, or 8 bits 

Bits 1:0 Character Length 

00 = 5 bits 
01 = 6 bits 

10 = 7 bits 

11 =8 bits 




Modem Control 

This register controls the handshake lines. 


Bit 7:2 

Reserved in SPARCbook 


Should be O’s 

Bill 

RTS Control 


0 = Assert RTS 

BitO 

DTR control 


0 = Assert DTR 


Line Status Register 

This register contains information about error conditions. The following conditiCHis are signified when 
the corresponding bit is at 1. 


Bit? 

Always 0 

Bit 6 

Transmitter Empty 

Bits 

Transmit Buffer Empty 

Bit 4 

Break Interrupt 

Bit 3 

Framing Error 

Bit 2 

Parity Error 

Bill 

Overrun Error 

BitO 

Receive Buffer Full 


Modem Status Register 

This register contains the information about modem lines. 

Bit 7 CuiToit DCD state 

Bit 6 CuiToit Ring Indicator state 

Bit S Current DSR state 

Bit 4 Current CTS state 

Bit 3 DCD changed since this register was last read 

Bit 2 Ring Indicator changed since this register was last read 

Bit 1 DCR changed since this register was last read 

Bit 0 CTS changed since this register was last read 


VPC CONFIGURATION 


A significant pration of the 82C710 circuitry is used for configuration, ail of which can be performed 
under software control. This permits user friendly (menu-driven) UPC configuration. DIP switches 
and jumpers are eliminated meaning that it is not necessary to open the chassis to change the configu¬ 
ration of a peripheral interface. 

Since the UPC is software configured, a setup program must be run whenever the configuration is 
changed. This jKocess entails placing the UTC in configuration mode and programming the on-chip 
configuration registers. 
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It should be noted that although the SPARCbook provides a PC-AT style hardware environment for 
the UPC, it does not use a standard BIOS implementation. The SPARCbook operating system man¬ 
ages all device configurations and it is therefore not normally necessary for the user to access the 
UPC’s internal registers. 


UPC Configuration Sequence 


In order to setup or change the configuration of the UPC, two consecutive addresses are used to select 
and access the internal configuration regist^. These are occupied by the Configuration Register 
Index (CRI) which is located at an even address and is used to point to the configuration register; and 
the Configuration Access Port (CAP) which is located at the next address, and is used to write data to 
the selected register. 

Before these two locations can be used, however, the UPC must be placed in Configuration Mode, and 
in the process an address for the CRI supplied. 

The UPC is located within the 8-bit I/O region of the SPARCbook’s address map. Any address 
chosen for the CRI will have to lie within this region. 

Hie configuration sequence comprises three steps; 

1 Entering the configuration mode 

2 Configuring the 82C710 

3 Escaping the configuration mode 

Entering Configuration Mode 

Assuming an address of 0x00CC(X)390 is selected for CRI, the following sequence would be used to 
enter the configuration mode: 

Write 0x55 to Ox00CC002FA 
Write OxAA to Ox0OCCOO3FA 
Write 0x36H to 0x00CC003FA 
Write 0xE4 to OxOOCC003FA 
(Whwe 0xE4 is 0x390 divided by 4) 

Write OxlB to OxOOCC002FA 
(Where OxlB is the complement of 0xE4) 

Following this sequence, the UPC is in configuratitm mode. If there is any departure from this se¬ 
quence, the UPC will revert to its idle state, and the sequence will need to be started again. 




Configuring the UPC 

To access and write data to any of the configuration registers, two writes are needed. 


First a pointer is written to the CRI; bit 3:0 provide the pointer to the configuration register, and bits 
7:4 should be set to 0. 

Following this, the data may be written to the selected regist^ via the CAP. 

Escaping Configuration Mode 

To escape configuration mode, write any value into the configuration register F, as follows: 

Write OxOF to 0x00CC00390 

Write Ox?? to 0x00CC00391 (?? = any value) 


Configuration Register Description 


There are sixteen configuration registers in the UPC. Settings are retained as long as standby power is 
maintained. 

These registers are not affected by the RESET signal aiKl are set to their default state only upon power 
up. Table 7-9 shows the configuration registers in the UPC with the default values upon power up, 
and values loaded by the SPARCbook resident firmware required fcff normal operation. 


OFFSET 

FUNCTION 

POWER UP 
DEFAULT 

SPARCbook 

DEFAULT 


Configuration 0 

OxOC 

OxOC 

0x01 

Configuration 1 

0x00 

0x40 

0x02 

Configuration 2 

OxOx 

OxOx 

0x03 

Reserved 

- 

- 

0x04 

UART Port Address - Unused 

OxFE 

OxFE 

0x05 

Reserved 

- 

- 

0x06 

Parallel Port Address 

0x9E 

OxCC 

0x07 

Reserved 

- 

- 

0x08 

Reserved 

- 

- 

0x09 

General Port Chip Select - Unused 

OxBO 

OxBO 

OxOA 

Configuration A 

0x00 

0x00 

OxOB 

Configuration B 

0x00 

OxFO 

OxOC 

Configuration C 

OxAO 

OxAO 

OxOD 

Mouse Port Address 

0x00 

0xC4 

OxOE 

Configuration E 

0x00 

0x00 

OxOF 

Configuration Index 

- 

- 


Table 7-9 UPC Configuration Registers 
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The only registers changed by the firmware are: 


Configuration Register 1 
Parallel Port Address 
Configuration Register B 
Mouse Port Address 

Configuration Register 1 

Only bit 6 in this register is changed in order to configure the parallel port for printer operation. All 
other bits retain their default settings. 

Bit 7 Reset Control 

This bit determines the manner in which the Reset pin affects the serial port The default is 0, normal 
Reset. 

Bit 6 Parallel Port Mode 

0 = Output, printer only 
1 = Bi-directional 

Bit 5 UART CTS Control - Not used 

Bit 4 UART DSR Control - Not used 

Bit 3 UART DCD Control - Not used 

Bits 2:0 Reserved 

Parallel base address 

This register holds the base address of the parallel port. The contents of this register are multiplied by 
4 to give the base address of the parallel port. A setting of OxCC identifies an address of 0x330. 

Configuration B 

This register is used to set the polarity of the interrupts issued by the UPC. All interrupts in the 
SPARCbook are prioritized by the MPI (see Chapter 5) which requires requests to be configured as 
active low. 

Bit 7 Mouse Interrupt Polarity 

0 = Active High 
1 = Active Lowf 

Bit 6 Floppy Interrupt Polarity 

0 = Active High 
1 = Active Lowt 

Bit 5 UART Interrupt Polarity 

Not used, should be 0 



Bit 4 Parallel Port Interrupt Polarity 

0 = Active High 
1 = Active Lx)wt 

Bit 3:0 Not Used 

t- Required by SPARCbook 

Mouse Port Address 

This register holds the base address of the mouse port. The contents of this register aie multiplied by 4 
to give the base address of the parallel port. A setting of 0xC4 identifies an address of 0x310. 


«. 
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CHAPTER EIGHT 
MODEM 


The SPARCbook is equipped with a modem interface which allows its connection via a public 
telephone system (in the US only) data communications or facsimile transmission. 

The modem intoface is implemented on the base board with a two-chip set cominising the SCI 1075 
modem access controUer (l^C) and the SCI 1054 modem, both from Siora SemiconducUH' Corpora¬ 
tion. These provide an extremely compact and low power interface with power management facilities 
to reduce power consumption when the modem is not in use. 

Figure 8-1 shows the implementation of the modem interface in the SPARCbook. 


RING INDICATOR 












MODEM OVERVIEW 


The SCI 1075 provides a direct interface between the host system and SCI 1054 modem; it incorpo¬ 
rates an Intel 8096 equivalent processor core, supporting an AT command set; contains a built-in 
16C450 equivalent UART; and contains 16Kbyte of on-chip ROM and 320bytes of RAM. 

The SCI 1054 is a complete 2400bps (bits per second) modem 1C which, when combined with the 
SCI 1075, provides Sendfax capability of up to 9600bps. 

The modem interface can be controlled using Hayes compatible commands written to the UART 
section of the MAC. Commands are sent to the int^face using character strings, and these are inter¬ 
preted by the MAC'S processor core and acted on appropriately. 

Command characters and data for transmission onto the telephone line are written into the UART's 
transmit buffer. Data received from the telephone line and status information from the MAC can be 
read from the UARTs receive buffCT. 

The modem interface operates in two modes: Command Mode or On-Line Mode. In Command Mode, 
characters written to the transmit buffer are regarded as being command characters. In the On-line 
mode, data written to this location (^art from the escape sequence -h~i-) are transmitted onto the 
telephone line. 
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INTERFACE CONTROL 


The host may access the UART registers within the MAC; the MAC contains a numbo' additional 
registers but these are accessible only by the internal microcontroller. TTie UART registers are accessi¬ 
ble at base address 0x00c400000 and are shown in Table 8-1. 

Bit 7 in the Line Control register is used as a pointer to either the transmit and receive buffers and the 
IRQ Enable register, or to the Divisor Latch regist^. Bit 7 must contain 'O' to gain access to the 
transmit and receive Buffers. 

The host is responsible for managing the transmit and receive buffers. During transmit q)erations, the 
host must supply data at a sufficient rate to ensure that there is always a new character for the modem 
to transmit; the modem is unable to wait and will regard an empty buffer as an error condition and 
disconnect the telephone line. During receive opmtions, the host must read the data in the buffer in 
time for the next incoming character from the telephone line. 

The Modem generates interrupts on IRQS when the receive buffer contains a character, when the 
transmit buffer is empty, and also to signal error conditions. All interrupt requests within the 
SPARCbook are marble and are prioritized by the MPI, encoding IRQS from the modem on the 
CPU level 8 interrupt request (see Chapter 5). 


ADDRESS 

REGISTER 

ACCESS 

00C400000 

Receive Buffer 

R 


Transmit Buffer 

W 


Divisor Latch (LSB)t 

R/W 

0OC4OOOO1 

Intemqrt Enable 

R/W 


Divisor Latch (MSB) t 

R/W 

00C400002 

Intemqrt ID 

R 

00C400003 

Line Control 

R/W 

OOC400004 

Modem Control 

R/W 

00C400005 

Line Status 

R/W 

00C400006 

Modem Status 

R/W 

OOC400007 

Scratch Pad 

R/W 


Table 8-1 UART Registers 

Note: t The divisor latch can be accessed only when bit 7 of the Line Control Register is set. 
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MAC Integral UART Registers 


This section describes the more significant registers in the UART, from the point of view of manag¬ 
ing the flow of commands and data between main memory and the UART. 

Interrupt Enable Register 

This register contains interrupt control bits. Setting one of the interrupt enable bits has the effect of 
enabling the associated interrupt request 

Bits 7:4 Reserved 

Bit 3 Enable Modem Status Interrupt 

Bit 2 Enable Receiver Line Status Interrupt 

Bit 1 Enable Transmitter Holding Register Empty Interrupt 

Bit 0 Enable Received Data Available Interrupt 

Interrupt Identification Register 

This register provides the identity of the highest priority pending interrupt condition, and a flag which 
indicates whether or not there is an interrupt pending. The UART prioritizes the internal interrupt 
requests as shown below. 

Bit 7:3 Reserved 

Bit 2:1 Interrupt ID 

11= Receiver Line Status - highest priority 
10 = Receiver Data Available 
01 = Transmit Buffer Empty 
00 = Modem Status - lowest priority 
Bit 0 Interrupt Pending Flag 

1 = No Interrupt Pending 
0 = Interrupt Pending 

Line Status Register 

The Line Status register contains infromation which allows the condition of the transmit and receive 
buffers to be monitored. 

Bit 7 Reserved 

Bit 6 Transmitter Empty 

This bit when set indicates that both the transmit buffer and the transmit shift register are empty 
Bit 5 Transmitter Buffer Empty 

This bit when set indicates that the transmit holding register is empty. It is cleared automatically 
when the host writes data into the transmit holding register 
Bit 4 Break Interrupt Flag 



Bit 3 

Framing Error Flag 

Bit 2 

Parity Error 

Bitl 

Overrun Error 

BitO 

Receiver Data Ready 


THE AT COMMAND SET 


This section describes the basic AT command set supported by the SCI 1075/1154 chipset, and the 
Sendfax extended command set. Table 8-2 provides a summary of the commands supported by the 
SPARCbook. 


CODE 

DESCRIPTION 

Basic AT Commands 


Go Off-hook in AnswCT Mode 


Re-execute Previous Command 


Attention Characters 


Bell/CCnr Protocol 


Dial Telephone Number 


Command Echo 


Switch Hook Control 


Identification 


speaker Volume 

M 

Speaker Control 

O 

Return to Online 

Qn 

Quiet Command Reset Code 

Sn= 

Writing to S-Register 

Sn? 

Reading From S-Regist» 

V 

Enable Short-form Result Code 

X 

Enable Extended Result Code Set 

&F 

Fetch Factory Configuration 

+++ 

Switch to Command Mode, but retain line connection 

Sendfax Commands 

#Bn 

Speed Control 

#En 

Received Frame Display Format Selection 

#Fn 

Mode Control 

#Pn 

Number of Pages to be Transmitted 

#Rn 

Resolution Control 


Table 8-2 Hayes AT Command Set Summary 
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The modem enters the Command Mode when it is reset, when it loses contact with a remote modem, 
or when it is in Data Mode and receives the escape sequence +++. 

When the modem is in Command Mode, it will accept instructions in the form of command lines, and 
in many instances will return respmises. The Command Mode allows the modem to be instructed to 
perform functions such as originating or answering a call. When the modem makes a connection with 
a remote modem, it sends a connect response to the CPU. 

Commands lines are written to the UART location at 0x00c400000 and responses are read from the 
same location. 

All commands lines begin with the characters AT (with the exception of A/), may contain one or 
more ccmimands and are terminated by a RETURN. Command lines may contain up to 40 characters, 
not including spaces. All characters before AT are ignored. 


Basic Command Set 


A Answer Incoming Call This forces the modem to go off-hook in answer mode. 

A/ Re-execute Previous Command The A/command repeats the last command. It is not pre¬ 
ceded by the AT characters or terminated by pressing 
RETURN. 


AT 

ATendon Characters 

These characters must appear at the beginning of all 



command lines. F 

Bn 

Bell/CCITT Protocol 

This command selects the communication standard: 



n = 0 

ccnr V.21 pn 



n= 1 

V.22A^.22bis 



n = 2 

V.23 

D 

Dial Telephone Number 

This command causes the modem to dial up a remote fl 



modem 

The following modifiers may be added: 1 1 



P 

Pulse Dial 



T 

Touch-tone Dial r 



R 

Originate Call in Answer Mode 



W 

Wait for Dial Tone 



» 

Delay a Dial Sequence p 
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@ Wait for Quiet 

! Go On-hook 

; Return to Command Mode 

S=n Dial a Stored Number 

En Echo Command Characters This controls whether the modem echoes command charac¬ 
ters back to the host: 



n = 0 

Characters Echoed 


n= 1 

Charact^ Echoed 

Hn Switch Hook Control 

n = 0 

Modem goes on-hook (hangs up) 


nss 1 

Modem goes off-hook to access the telqjhone line 

In Identification 

This command causes the modem to respond to the host by 


providing identification codes: 


n = 0 

Request Product Code 

n= 1 

ROM Checksum 

n = 2 

Return OK Response 

n = 3 

Manufacturers ID 

n = 4 

ConEguration Mode 

n = 33 

Sierra ID 


O Return to Online This command is used to return to the MAC to the Data 

Mode following an escape sequrace used to enter Com¬ 
mand Mode. 


Qn Command Response Control This command controls whether the modem provides 

responses to commands: 
n = 0 Return Response to host 
n s 1 Do Not Send Response 

Sr=n Change Register Value This command selects an S register and changes its con¬ 

tents: 
r = 0-27 
n = 0-255 


Sn? Read S Register 


This command returns the contents of an S register 
n = 0-27 




Vn Response Format 


This command is used to select the format of response 
made by the modem to the host' 
n = 0 Single Digit Response 

n = 1 Extended Response 

Xn Select Extended Response Set 

&F Fetch Factory Configuration This command recalls the factory settings of the modem 

chipset 

Sendfax Command Set 

#Bn Speed Control This command selects the initial fax transmission speed: 

n = 4 2400 bps 

n = 5 4800 bps 

n = 6 7200 bps 

n = 7 9600 bps 

#En Received Frame Display Format This command selects the display format for 

HDLC frames: 

n = 0 Disable Display of HDLC Frames 

n = 1 Display Frame in Binary Format 

n = 2 Display Frame in 2 Digit ASCII Hex Format 

#Fn Mode Control This Command selects the modem operating mode 

n = 0 Return to Normal Mode 
n = 1 Enter Fax Mode 

#Pn Number of Pages to be Transmitted n = 0 to 2SS 

#Rn Resolution Control This command selects the resolution used for document 

transmission: 

n = 0 Send Document with Normal Resolution 
n = 1 Send Document with Fine Resolution 
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S-REGISTERS 


The MAC maintains a set of registers which can be written to and read using the S-register commands 
described previously. There are twenty-eight S-Registers summarized in Table 8-3. 


REGISTER 

FUNCTION 

SO 

Rings Until Auto-answer Calls 

SI 

Count Number of Incoming Rings 

S2 

Escape Character 

S3 

Carriage Return Character 

S4 

Line Feed Character 

S5 

Backspace Character 

S6 

Dial T(Mie Wait Time 

S7 

Wait Time for Remote Carrier 

S8 

Comma Pause Time 

S9 

Carrier Detect Response Time 

SIO 

Delay Time Between Loss of remote Carrier and Hang-up 

Sll 

DTMF Dialing Speed 

S12 

Escape Guard Time 

S13 

Reserved 

S14 

E, Q, V Commands; Accept or Ignore Commands; TPDA Commands 

S15 

Reserved 

S16 

Modem Loopback Tests 

S17 

Reserved 

S18 

Modem test Timer ” 

S19 

Reserved 

S20 

Reserved 

S21 

J, &R, &D, &C, &S, Y Commands 

S22 

L, M, X, &P, &T4, &T5 Commands, DTE Speed. Parity 

S23 

&T4 and &T5 Commands, DTE Speed, Parity 

S24 

Reserved 

S25 

DTR Delay for Synchronous Operation 

S26 

RTS/CTS Delay 

S27 

&M, &L, &X and B Commands 


Table 8-3 S-Register Summary 






Reading an S-Register 

The current value of an S-Register can be read using the Read S-Register command. For example, the 
command line: 

ATSO? 

will cause the modem to respond by returning the contents of the S-Register 0 in three-digit form 
followed by OK. 

Changing an S-Register 

The contents of an S-Register can be changed using the Change S-Register Command. For example, 
the command line: 

ATS0s2 

will cause the modem to change the contents of S-Register 0 to 2. The modem responds by returning 
OK. 


FAX RESPONSES 


When a command is executed by the MAC, the hardware may repeat the result to the host Status 
information is returned to the host in the form of responses. The MAC may return short response 
codes consisting of a single character (or digit), or verbose responses consisting of a string of charac¬ 
ters. The responses produced as a result of a fax session are summarized in Table 8-4. 




VERBOSE 

DIGIT 

MEANING 

CED 

a 

Answertone Detected 

CFR 

g 

Remote Machine confirmation to receive 

CONNECT2400/FAX 

w 

Connection Speed 2400bps 

CONNECT4800/FAX 

X 

Connection Speed 4800bps 

CONNECT7200/FAX 

y 

Connection Speed 7200bps 

CONNECT9600/FAX 

Z 

Connection Speed 9600bps 

CRC ERROR 

e 

Error in received frame 

CPR 

c 

Rq)eat Request 

CSI 

- 

Remote Machine Identification 

DCN 

d 

Disconnect 

DIS 

b 

Remote Machine Capabilities Frame 

FTT 

f 

Failure to Train 

INVALID FRAME 

i 

Received Frame Invalid 

MCF 

m 

Message Received OK 

RTN 

h 

Message Not Received OK 

RTF 

j 

Retrain Positive 


Table 8-4 Response Summary 










CHAPTER NINE 
ETHERNET INTERFACE 


The SPARCbook is equipped with an Ethernet interface which allows its connection to a network for 
fast communications with other workstations, fileservers, printservers, and so on. 

This section of the SPARCbook Technical Reference describes how the Eth^et interface in the 
SPARCbodc is implemented. An in-depth discussion about networking is beyond the scope of this 
manual, but a brief overview is provided. 


Figure 9-1 SPARCbook Network Connection 
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NETWORKING OVERVIEW 


Ethernet is a send and receive half duplex serial communications system capable of data u^sfers at 
up to 10 million bits per second. 

A networking standard has been formalized by the Institute of Electrical and Electronic Engineers in 
the IEEE802.3 standard. This defines the type of cables and cminections used to form the network, 
the topology of the network and the protocols which control access to the network. 

Coupling the SPARCbook to a netwoilc cable requires an external network transceiver and transceiver 
cable (sometimes called a ‘drop cable’). The network transceiver is attached to the network cable, and 
the transceiver cable is connected between the 15-way locking D-type connector on the rear of the 
SPARCbook and the network transceiver, as illustrated in Figure 9-1. 

The transceiver transmits and receives the data carrier signal on the network cable. In addition, it 
provides isolation between the SPARCbook and network so that its addition to or removal from the 
network does not affect the network. The transceiver is also responsible for detecting ‘collisions’, 
which occur when two or more nodes attempt to transmit simultaneously. 


Ethernet Protocol 


The IEEE802.3 standard specifles a Carrier Sense Multiple Access with Collision Detection protocol 
(CSMA/CD) as a simple and efficient means of determining how a node may gain access to and 
transmit information over the network. 

Carrier Sense ’ 

A node wishing to transmit data over the network must frrst listen to the cable to detect whether 
another station is already using the cable. Transmission is deferred until the cable is clear. 

Multiple Access 

Any station wishing to transmit may do so if the cable is clear. There is no central controller to 
allocate use of the network. 

Collision Detection 

This provides a mechanism for resolving the situation which may occur when more than one station 
starts to transmit at precisely the same moment Each transmitting station listens to the signal on the 
cable. If more than one station is transmitting, then the signal on the cable will no longer be the same 
the signal being transmitted, but will be garbled; i.e. a collision will have occurred. In this situation 





the competing stations continue to transmit for a time in order to ‘jam’ the network, which signals the 
collision to other stations on the network. All competing stations then suspend tamsmission for a 
random delay before attempting again. 


Basic Operations 


At any given time, stations attached to the netwodc function as eith^ a transmitter or receiver. Data is 
passed between stations in bursts (or packets) at up to 10 million bits per second. 

An Ethernet packet contains the destination address of the intended recipient, the source address 
identifying the sender, the data length and then the data itself. The format of an Ethernet packet is 
shown in Figure 9-2. 


6Bytes 

6Bytes 

2Bytes 

46 - ISOOBytes 

4Bytes 

Destination Address 

Source Address 

Length 


CRC 


Figure 9-2 Ethernet Packet 


Transmission 

Packets are placed into an area of buffer memory by the CPU ready for transmission by the Ethernet 
controller. Tlie Ethernet controller automatically performs a cyclic redundancy check (CRC) during 
transmission and spends a 4byte result to the end of the packet as a frame check. The overall length 
of the packet must te between 64 to ISlSbytes, including the checksum; ptulding may be added by the 
controller to achieve the minimum required length if required. The controll^ also adds a preamble 
and synchronization pattern to the start of the packet to enable detection and synchronization by the 
receive. A Manchester encoder produces a differential signal which carries the data and an embedded 
clock signal onto the network cable. 

Reception 

When the receiver node detects a carrier on the network, it passes the incoming packet to the Man¬ 
chester decoder within the controller. A phase locked loop synchronizes with the preamble to allow 
recovery of the clock signal and data. The controller examines the destination address in the header 
and stores packets containing a valid address in a buffer memory where it can be read by the CPU. 
During reception, the receiver performs a CRC and checks the result against the frame check. Dis¬ 
crepancies are reported as CRC errors. 
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Errors 

The Ethernet controller reports any errors, such as CRC errors or missed packets, to the host using 
interrupts and error bits in its status registers. 

Addressing 

Tbere are three addressing modes. The first mode is physical addressing which uses the 48-bit (6byte) 
destination address in the packet header to uniquely identify one receiver. The physical address 
requires comparison by a receiver with its own uniqiK ‘Node ID’. The issuing of Ethonet addresses 
is overseen by the IEEE, ensuring globally that no two stations share the same physical address. Each 
SPARCbodc has its own unique Ethernet address programmed into it during manufacture. 

The second mocte is Multicast (or Logical) Addressing which may be used to send packets to sev^ 
receivers at once. The third mode is Broadcast Addressing, where packets are sent to every node 
attached to the network. 


THE SPARCBOOK ETHERNET IMPLEMENTATION 


The Ethernet interface in the SPARCbook is implemented with a Fujitsu 86960 Networic Interface 
Controller with Encoder/Decoder (NICE). NICE is a highly integrated device which incorporates a 
Manchester encoder and decoder, a data link controUer, and a buffer memwy management unit in a 
single chip. 

Figure 9-3 illustrates the architecture of the Ethernet interface in the SPARCbook. 



Figure 9-3 Ethernet Interface Architecture 
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The NICE is provided with a dedicated 64Kbyte buffer memory accessible to the SPARC CPU (or 
host) via a 16-bit buffer port. The NICE allows multiple data frames to be transmitted directly from 
the buffer to the netwoilc with a single transmit command. 

The interface between the NICE and the SPARC CPU is provided by the MPI (see Chapter 5). The 
MPI transfers data between the buffer memory and the hftus via intOTial FIFOs and provides data 
packing between the Mbus and Pbus, allowing the CPU to access the buffer memory using 64-bit 
single cycle or burst accesses. 

Fabricated in low power CMOS technology, the NICE features a stand-by mode which can be used to 
reduce its pow^ consumption when the network interfK;e is not in use. The SPARCbook’s pow^ 
management facility takes full advantage of this feature in ord^ to maximize battoy life. 


FUNCTIONAL DESCRIPTION OF THE NICE 


The MB86960 incorporates four major functional elements, as shown in Figure 9-4, these are; 

• Host System Interface 

• Buffer Management Unit 

• Data Link Controller 

• Manchester Encoder and Decoder 



Boffer 

BiteifacB 


Figure 9-4 NICE Simplified Block Diagram 
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NICE Host System Interface 


The host system interface provides the connection between the NICE’S internal registers and buffers 
and the Pbus and hence the SPARC CPU. The NICE contains three register sets. These are the Data 
Link Controller Register set, the Multicast Address Register set, and the Buffer Port Memory Register 
set. These are shown in Figure 9-5. 

Data Link Controller Register Set 

The Data Link Controller register set contains sixteen legists which are used by the host to initialize 
and control the activity of the NICE, and to provide the host with error status information. The lower 
eight registers of this groq) occupy the lower eight address locations within the NICE’S address space, 
and are always accessible. The upper eight registers in this group share the NICE’S remaining address 
space with the two other register groups. 

Bits 2 and 3 in Control Register 2 are used to select between the register groups sharing the upper half 
of the NICE’S address space, as illustrated in Figure 9-5. 


Register 

Address 

0x00020000 

0x00020001 

0x00020002 

0x00020003 

0x00020004 

0x00020005 

0x00020006 

0x00020007 


0x00020008 

0x00020009 

Ox0002000A 

0x00O2000B 

0x00020000 

0x00O2000D 

0X00O2000E 

0x00O2000F 


Data Link Oontrolier Set 



Oontrc^ Register 2 
Bits 3:2 



RegistBi 

Bmk 

1 

Reguter 

Bank 

0 







Figure 9-5 NICE Internal Registers 
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After initialization, it is normally only necessary to access the lower eight registers in the Data Link 
Controller registers, to obtain status information, and the Buffer Memory Port to read and write data 
packets and to issue transmit commands. 

The NICE supports 8- or 16-bit accesses, little or big-endian byte ordering and can provide DMA 
support. In the SPARCbook implementation the NICE should be set up with a 16-bit interface and 
little endian addressing. The NICE’S own DMA facilities should be disabled; these are not used 
because host accesses to the NICE are controlled by the MPI. 

When the NICE receives a data packet from the network, it checks the header information for a valid 
destination address. 

Physical addresses, those with a ‘O' in the least significant bit, are compared with the contents of the 
Node ID registers in the Data Link Controller Register set These combine to form a single 48-bit 
node ID. When an address match occurs, the receiver transfers the incoming packet into the receive 
buffer memory. 

Mask Address Register Set 

All eight registers in this set combine to provide a 64-bit logical address filter (or hash Alter). A 
multicast (or logical) address is idendfied by a T’ in the least signiAcant bit of the destination address 
ccmtained in the packet header. 

When the NICE detects a ‘ 1’ in the Arst bit of an incoming address, it passes the address through its 
int^nal (TRC logic. This produces a 32-bit result The least signiAcant 6bits of this result are used to 
provide an address for one of the 64bits contained in the eight multicast address registers. If the bit 
selected is a ‘ 1’, then the packet is accepted into the receive buffer. 

This mechanism provides the NICE with the ability to recognize up to 64 destination addresses At)m 
the network as being possibly valid for the SPARCbook; the software has to examine the validity of 
the address, but has to do so far less often than if every address had to be checked in software. 

MulAcast address Altering is illustrated in Figure 9-6 
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32 


Destmation Address 


0 


Multicast Address (Bit 0=1) 


CRC 

Logic 

Enable 


CRCReiultmt 


5_0 



6-bit Address 
selects one bit from 
Multicast Address Filter 


Multicast Address Registers S3 S6 SS 4847 40 39 3231 2423 1615 8 7 0 

a N^*^N**^^*|MAR13|MAR12|MARtl|MAR10|MAR9 [blARg 


Figure 9-6 Multicast Address Filterering 


Buffer Port Memory Register Set 

The Buffer Port Register set provides the host with access to the transmit and receive buffer memory 
and also contains packet control and DMA control registers. 

The Buffer Memory Port allows the host to write data into the transmit buffer using 16-bit transfers. 
The NICE maintains internal pointers so that rqieated writes to this location are automatically directed 
to the next 16-bit location. Similarly, the internal pointers allow successive reads of the Buffer 
Memory Port to access successive 16-bit locations in the receive buffer memory. 

Bit 7 in Packet Control Register 1 is used by the host to command a start of transmission, and bits 
6:0 are used to inform the buffer manager of the number of packets to be transmitted, allowing back to 
back transmission of up to 128 packets. 

The DMA control regist^ should be cmifigured to disable DMA operations by the NICE. 


Buffer Manager 


Two SRAM devices provide the NICE with a 64Kbyte buffer memory. The Buffer Manager within 
the NICE automatically prioritizes and services requests for access to the buffer from the host and 
Data Link Controller. It updates all buffer pointers and allocates memory space for incoming packets, 
and provides status information via the status registers. 

In the SPARCIbook, the CPU is able to write to the Buffer Memory Port using 64-bit single cycle 
accesses or burst accesses via the MPI (see Chapter 5). The MPI automatically converts a 64-bit 
access into a sequence of four 16-bit cycles on the Pbus. 
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Figure 9-7 Transmit and Receive Buffer Memory Organization 


The buffo' contains two areas: one for transmit data and one for receive data. These are shown in 
Figure 9-7. 

Transmit Buffer 

The transmit buffer may be conflgured in software, via Control Register 1, as a single banked 16Kbyte 
buffer or a dual banked 4,8 or 16Kbyte buffer. With a dual banked configuration, the host is able to 
write to one bank while the Data Link Controller transmits from or receives pactets into the other 
bank. The internal pointer controls bank and location selection within the buffer transparently to the 
programmer. The NICE switches banks each time a Start Transmission command is issued. 

When all packets to be transmitted have been loaded into the buffer, transmission is initiated by 
programming the number of packets in Packet Control Register 1 bits and assming the transmit start 
bit in the same register. 

Receive Buffer 

The receive buffer occupies the remaining space in the buffer memory after the allocation of the 
transmit buffer size. 

Each received packet is preceded by a 4byte header. The first byte provides status information, the 
second cmitains irrelevant data, and the remaining two contain the packet length. Reading more than 
the indicated number of bytes will advance the internal pointers beyond one packet and into the 
beginning of the next or may cause a bus read error. Reading fewer bytes will leave garbage at the 
start of the next packet 
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INTERRUPTS 


All interrupts in the SPARCbook are handled via the MPI (see Chapter 5). The NICE produces an 
active low interrupt on IRQ level 7. 


Interrupts are generated when a packet is transmitted or received, or if a transmit or receive error 
occurs and the ccmesponding mask is set. 



CHAPTER TEN 
DISPLAY CONTROLLER 


The SPARCbook uses a CL-GD6410 to provide control of the LCD flat panel display built in to the 
SPARCbook and an external CRT monitor. It provides a VGA subsystem for SPARCbodt allowing 
the user to operate an externally connected analogue CRT VGA monitor without disabling the LCD 
display, and without using a VGA add-on card. The CL-GD6410 supports the generic VGA monitor 
concept advanced by the Video Electronics Standards Association (VESA) for 3S0,400 and 480 scan 
line monitors. 

Models fitted with a color LCD display also contain a CL-GD6340 Color LCD Controller. This 
provides additional int^acing between the display controller and color LCD display. To software, 
the display ctMitroller and color LCD controller appear to be one device. Each one decodes addresses 
for accesses to its internal registers and color palette. 


Figure 10-1 
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DISPLAY INTERFACE OVERVIEW 


The CL-GD6410 interfaces directly to the CPU via the 16-bit Pbus and MPI, to 256 Kbytes of video 
memory and to the display devices. 

The SPARCbook is equipped with a 640 x 480 pixel monochrome or color LCD panels. The color 
version is able to display up to 16 colors simultaneously from a palette of 262144, while the mono¬ 
chrome version provides color to grayscale rendering to display 16 gray levels. Color to grayscale 
rendering allows color images to be displayed to good effect on the monochrome LCD display. 

The CL6410 provides a host interfacewhich allows access to its internal control register, color palette 
and display memory. The CL6410 also incorporates a digital to analogue converter which transforms 
color information from the color palette into Ae RGB signals required to directly drive a color CRT 
display. 


HOST INTERFACE 


In the SPARCbook, the MPI provides the SPARC CPU with direct access to the CL-GD6410. 
Memory reads and writes use 16-bit bus cycles, while I/O commands use 8-bit bus cycles. 

Some of the internal registers within the CL-GD64I0 and CL-GD6340 can be accessed directly by the 
host, but many others are accessed via index registers. To access an extension register, a points to 
the required register is written to the index registers and then, in a second access cycle, the data is 
written to or read from the selected register. During register accesses by the host, memoy accesses 
by the CL6410 and screen refresh activities continue to occur uninterrupted. 

Host accesses to video memory are channelled via the CL-GD6410. The SPARCbook resident 
firmware establishes the proper address/data/timing paramet^ in the CL-GD6410 registers in order 
to transfer to and from video memory. The CL-GD6410 also contains an intelligent address sequencer 
that allocates video memory cycles to the host, to the VRAM refresh and the display CRT controllers. 

Although the SPARCbook provides a PC-AT style hardware environment for the display controllers, 
it does not provide a standard BIOS. Configuration of the display interface is normally carried out via 
the operating system, as described in the SPARCbook User’s Guide. 


n 

I 


n 


n 


130 




ADDRESS 

VGA PORT 

Ox0OCOO03B4 

CRTC Index MP(r/w) 

0x00C0003B5 

CRTCDataMP(r/w) 

OxOOCOOOSCO 

Attribute Controller Index (r/w) Data (w) 

OxOOCOOOBCl 

Attribute Controller Data (r) in VGA 

Attribute Controller Data (r/w) in EGA 

0x00C0003C2 

Misc Output (w). Feature (r) 

0x00C0003C3 

Motherboard Sleep Address (r/w) 

In address space only if switched enable. 

OxO0C0O03C4 

Sequencer (r/w) 

0x00C0003C5 

Sequencer (r/w) 

OxOOCOO03C6 

RAMDAC Pixel Mask (CPRd and CPWr) 

0x00C0003C7 

RAMDAC Address Reg. Read Mode(w) 

(affects CPWr on writes) 

RAMDAC Status Register 

0x00C0003C8 

RAMDAC Address Register Write Mode (CPRd and CPWr) 

0x00C0003C9 

RAMDAC Data (CPRd and CPWr) 

0x00C0003CA 

Feature Control (r) 

0x00C0003CC 

Misc Output (r) 

0x0OC0O03CE 

Graphics Controller and Extensions Index (r/w) 

0x00C0003CF 

Graphics Controller and Extensions Data (r/w) 

0x00C0003D4 

CRTC Index (r/w) 

0x00C0003D5 

CRTC Data (r/w) 

0x00C0003DA 

Feature Control (w). Display Status (r) 

0x00C0046E8 

AT Adapter Sleep Address (r/w) (if switch enabled) 


Table 10-1 Display Controller Memory Map Summary 


Host Accesses to the Color Lookup Table 


To write a color definition to the lookup table, a value specifying the address location in the lookup 
table is first written to the RAMDAC Write Mode address register. Following this, the coIot values 
for the red, green and blue intensities are written in succession to the RAMDAC Pixel Data register. 
After the blue data is latched, the new color data is transferred into the lotdtup table at the defined 
address, and the address register is incremented automatically to point to the next palette location. 

Read operations are similar but use the RAMDAC Read Mode Address regist^ to point to locations in 
the color palette. 

If the address register is loaded with a new starting address while an unfinished sequence is in 
progress, the system resets and starts the new sequence. 
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Display Access to Video Memory 


The GD6410 contains video shift registers which interface with the display. It performs the operations 
necessary to fetch scan line data from the font bitm£q)s, while seperately controlling the video memory 
address buses. 

The display interface in the SPARCbook is operated in a bit-mapped gn^hics mode, with 4bits/pixel. 
The pixel data is used to address entries in the color palette, selecting red, green and blue color value 
for that pixel to be output to the DAC. The GD6410 monitors the active and inactive areas of the 
screen and cursor position, and supplies the HSYNC, VS YNC, BLANK and Display Enable screen 
control signals. 

The GD6410 is connected directly to a monochrome dual-scan LCD display. An additional 64K x 4 
DRAM is provided to act as a frame accelerator for split-panel data formating. Data from the frame 
accelerator and the video memory is supplied in parallel to the 4-bit upper and lower panel data buses 
of the LCD flat panel. This technique maintains normal display contrast but reduces the power 
consumption of the video circuitry becuase the rate at which data is fetched from video memory is 
effectively half the panel frame rate. 

In the color version, the CL-GD6340 takes the pixel information for the LCD and provides color 
mapping for the coIot LCD display. 


INTERNAL RAMDAC OPERATION 


The GD6410 and GD6340 both include an internal RAMDAC. A RAMDAC consists of an area of 
RAM containing a color lookup table (or color palette) and a digital to analogue converter. 

The color palettes contain 256 x 18 color lookup table which is addressed by pixel information from 
the VRAM to jHovi^ three 6-bit color values for each pixel. The digital to analogue converter 
converts the three 6-bit values from the palette into the analogue red, green and blue video signals 
required to drive a CRT. The RAMDAC also provides a pixel mask register and a border color 
register. 

The two color palettes occupy the same address in the SPARCbook's address map so that the color 
mappings contained by the two display controllers are always identical. Since the external CRT is 
controlled by the GD^IO in both the monochrome and color models of the SPARCbook, identical 
color palettes in the two devices ensures color consistency between the color LCD and CRT displays 



SIMULTANEOUS DISPLAY ENABLING 


Simultaneous display operations are controlled by the CL-GD6410 using the Display Mode Register, 
the Write Control Register, and the CRTC Test Register 

The CL-GD6410 includes all registers and data paths required for VGA compatibilty. VGA enhance¬ 
ments include sixteen simultaneously loadable text fcmts, Write Mode 3 and readable registers. The 
CL-GD6410 supports extended-resolution display modes with CRT displays. 

Extended graphics resolution of 800 x 600 mode with a 4:3 aspect ratio can be displayed using 
multihrequency analog CRT monitors. 

High-resolution text modes of between 100 columns by 30 rows and 132 columns by 60 rows can be 
supported on analog CRT monitors by the CL-GD6410. Text modes of up to 100 columns by 30 rows 
are supported for 640 x 480 LCD flat panel displays. 

Grayscaling and color rendering for the LCD displays is accomplished by modulating the ON-to-OFF 
time of individual pixels in the panel and allowing the eye to integrate the superimposed pixels to 16 
perceptible grays levels on a monochrome display or 2S6 colors on a color display. Flicker is elimi¬ 
nated by proprietary Cirrus Logic techniques involving distribution of time between ON and OFF 
pixels during frame modulation. 


INTELLIGENT POWER MANAGEMENT AND SEQUENCING 


Notebook and ltq)top PCs have stringent power limitations due to battery qjeration and heat dissipa¬ 
tion. To meet these needs, the CL-GD6410 is manufactured using low-power CMOS technology. In 
addition, the CL-GD6410 has programmable output pins as well as other intelligent powo* manage¬ 
ment features 

Normal Mode Conditions 

• Power to LCD panel and full screen refresh 

• CPU access to video memory 

• Refresh to video memory 

• CPU access to the I/O registers and the RAMDAC 




Standby Mode Conditions 


• No power to LCD panel; no screen refresh 

• Panel power Sequencing is observed 

• CPU access to video memory, I/O registers and the RAMDAC 

• Refresh to video memory 

• Frequency Synthesizer remains powered-up 

The primary power savings in this mode comes from shutting down power to the LCD panel only. 
Since there is no screen refresh, normal clock rates are not required and may be replaced by slower 
clock rates to further reduce power consumption. Any RAMDAC I/O can executed. 

The system will recover from standby mode after detecting either video memory read or write ac¬ 
cesses or the presence of the SSCLK signal. If power sequencing is in progress, then the CL-GD6410 
will allow the sequencing to complete before exiting from standby mode. 

Power-save timers that allows it to be programmable in increments of 1 minute up to 63 minutes. If 
the power-save timer is enabled, the programmed time-out time from the last stimuli is used to 
automatically switch to standby mode. The timer can be activated by either the SSCLK signal or by 
reads or writes to CPU memory access. 

Suspend Mode 


• No power to LCD panel; no screen refresh 

• Panel power sequencing is observed 

• Refresh to video memory continues 

• No CPU access to RAMDAC, video memory, or registers 

• Frequency Synthesizer is powered-down 

The power savings in this mode occurs because host access to video memory is denied, and a slower 
clock is in use. This slow clock refreshes video memory by keeping CAS low and pulsing on RAS 
throughout the Suspend Mode. If slow-refresh DRAM is used, a clock running as slow as 32 kHz can 
be used, clocking both edges. Other than this refresh logic, the rest of the CL-GD6410 has no clocks, 
reducing poww consumption even further. 

Suspend Mode can be activated or deactivated, under program control. 





Shut Down 


Prior to initiating a system-wide shutdown, the system can save the state of the video subsystem so it 
can be restored later. The CL-GD6410 allows the system to save or restore the status of all controller 
registers. 

A pixel word mask is incorporated to allow the incoming pixel address to be altered or masked, 
permitting changes to the color lookup table contents to be made immediately. This feature allows 
special display operations such as flashing objects and overlays to be created. 

The color lookup table contents are accessed via its 8-bit-wide host interface. An internal synchroniz¬ 
ing circuit allows the color value accesses to be completely asynchronous to the pixel video operation. 
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CHAPTER ELEVEN 
MK48T02 BATTERY BACKED 
REAL TIME CLOCK AND SRAM 


The MK48T02 is a 2Kbyte zero power timekeeper and RAM which combines a CMOS SRAM, a 
bytewide accessible real-time clock, a crystal oscillator and a long life lithium-carbon-monofluoride 
battery in a single package. The device appears as an ordinary 2K x 8 RAM array with the added 
advantages that data is retained during power-down periods and that the uppermost 8bytes provide an 
accurately updated real-time clock. 

Hie RTC/RAM appears in the SPARCbook address map at address OxOOCbOOOOO. Within the 2Kbyte 
space that the device occupies, the RTC is contained in the uppermost 8bytes, and the RAM the 
remaining 2040bytes. 
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BATTERY BACKED SRAM _ 

The battery-backed RAM of the MK48T02 is used in the conventional manner. The power-up and 
power-down transitions to and from the battoy-backed mode are handled automatically by the 
hardware and do not require any special intervention from the user. 


REAL TIME CLOCK _ 

The Real Time clock area of the MK48T02 consists of 8 registers which contain the clock data and 
control information. The register organisation of the MK48T02 is shown in Figure 11-1. 


0x00C6007FF 
0x00C6007FE 
0x00C6007FD 
oxooceooTFc Irest 
OxOOCeOOTFB Start 

rTatjimiw itiYiYiYiYaYl 

0x00C6007FA 
OxOOC6007F9 Stop 
0x00C6007F8 WR RD | 
0X0OC60O7F7 


Date 


mmmmi 

Day 


Hour 

Minutes 

Seconds 

Calibration Data 


2040 BYTES 
SRAM 


0x00C600000 
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RTC Operation 


Within the RTC are a number of Binary Coded Decimal (BCD) counters configured to operate as a 
seconds, minutes, hour, day/date, month and year counter chain. A set of read-write registers are used 
to communicate with the counter chain. The counter chain is timed by a quartz crystal oscillator and 
programmable calibrator which generate accurate master signals to clock the entire RTC. Finally, a 
set of control and status bits are used to control of the oscillator, calibrator and read and write regis¬ 
ters. 


The control bits which govern the read and write operations to the RTC are bits 6 and 7 of the control 
register. These are positive polarity enable bits which control the transfer of data between the RTC 
counter registers and the external bus. 

When the Read bit is set, the data at the RTC counter output is latched into the RTC read registers. In 
this mode the unchanging RTC data can be read accurately. Although the RTC data is stationary 
when the Read Bit is asserted, the RTC counter stages continue to be iqidated in the normal manner. 
When the RTC data has been read, the Read bit should be cleared. C(Hiventi(»ial read operations of 
the RTC counter registers are possible when the Read Bit is ‘O’, but in this mode the changing data 
cannot be guaranteed to be read correctly. 

When the write bit is set, values may be written into the RTC. In this mode a complete set of time and 
date information may be assembled at leisure within the relevant RTC inputs. When the Write Bit is 
subsequently cleared the assembled time information is transferred in one operation into the RTC 
counters. The RTC then recommences operation from this point with the new information. 

When the RTC is not required for v^ long periods of time (many months), it can be placed in a low- 
power mode to extend the battery life. In this case the oscillator is halted and normal RTC operation 
ceases. The low power mode is initiated by setting the ST bit, the most significant bit (bit 7) of the 
Seconds register. The typical lifetime of the RTC/SRAM is expected to be in excess of 7 years for 
most operating conditions. 



In order to start the oscillator again, not only must the Stop bit be reset back to a ‘O’, but also the Start 
bit must be taken slowly through a 0,1,0 cycle. In this case the complete start-up sequence is 
follows: 

1. Set the Write bit to a 1 - to enable write operations to the RTC 

2. Reset the Start bit to a 0 - to enable oscillations 

3. Set the Start bit to a 1 - to set up the Start Oscillator command 

4. Reset the Write bit to a 0 - to issue the Start Oscillator command 

5. Wait 2 seconds - to allow the Oscillator to settle 

6. Set the Write bit to a 1 - to enable write operations to the RTC 

7. Reset the Start bit to a 0 - to turn off kick-start mode 

8. Set the correct time and date 

9. Reset the Write bit to a 0 - to transfer new data into the RTC 


Real Time Clock Calibration 


Although the RTC has good time-accuracy, the final operational accuracy will depend on the tempera¬ 
ture and temperature-stability of the operating environment 

Recalibration is poformed by writing a calibration value into the control register. This figure is used 
to periodically add or subtract pulses from the RTC chain. The value that is required for compensa¬ 
tion can be calculated most easily firom a knowledge of the parts-per-million (ppm) error of the RTC. 
This can be derived from the quantity of error which accumulates over a known time period. 

The calibration value that is written into the control register is the ppm error divided by -2.034; that is, 
the RTC can be calibrated in increments of 2 ppm (approximately). The calibration data occupies the 
lowest 6 bits of the control register. Of this data, the lowest S bits constitute a calibration value and 
the most significant bit is a sign bit. When the sign bit is a z^, the calibration figure is negative and 
controls how much slowa the clock will run; when the sign bit is a one, the calibration value is 
positive and controls how much faster the clock will run. 
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CHAPTER TWELVE 
SI-BASE SCHEMATICS DESCRIPTION 


Sheet 1 DRAM CONTROL 


The MACH210 device (U39) is a progammable device similar to a PAL but considnably larga. Full 
details of the mode of operaticm of this device are available in Chapter S. It is used as the DRAM 
State MtK:hine, controlling the operation of the DRAM array. 

The TS32A (U43) is used as the DRAM address multiplexer, providing the Row and Column ad¬ 
dresses for the DRAM array on the BMA lines. The multiplexing is ctmtroUed by the signals / 
ROWEN and /COLEN gen^ted by U39. The address is latched from the MAD lines into the ‘B’ 
side of the TS32A by the signal MCLK qualified by the signal /MAS, which is the synchronized cycle 
start signal. /MAS is generated by U1 on Sheet 1 of the Sl-CPU board schematics. Three of the 
multiplexed address lines (BMAO, 1 and 10) are driven by the TS32A during the Row Address phase 
and by U39 during the Column Address phase. 

U43 also latches MAD(3:0,41:40) onto the permanently enabled DLA lines and MAD(36) onto the 
permanently enabled READ line. These are used as control signals by U39. 

U19 and USl are the Parity Storage DRAMs, holding one parity bit per byte for the entire memory 
array. Write-Per-Bit DRAMs are used, which allow any combination of the x4 active bits at each 
address to be altered in a single cycle (masking off the remaining bits). The masking is carried out by 
writing a code to the device on the data lii^ during the Row Address phase of the Write cycle. U12 
is used to buffer the code supplied by U39 onto the parity data bus, PARD(7:0), and is enabled during 
the Row Address phase by the signal /ROWEN from U39. 






SHEET 2 DRAM 


The DRAM is organized into a 64-bit wide array, using sixteen x4 devices, either 4Mbit or 16Mbit 
fast page mode chips. The array is subdivided into two 32-bit wide blocks, the Upper and Lower 
blocks, which are identified by the use of the /RASU and /RASL signals. These, combined with the 
CAS(3:0) signals, allow valid combinations of byte, halfword, word and doubleword to be made 
active. Note that accesses that are unaligned across the upper and lower block boundaries are not 
catered for - the Parity Storage system will not cater for these types of (illegal) access. The DRAMs 
take the row and column addresses from the BMA(11:0) lines and data is on the MD(63:0) bus. 


Sheet 3 PARITY GENERATION 


On the right-hand side of the sheet are eight ACTl 1286 devices (U7, U11, U14, U21, U40, U41, U49 
andUSO). The ACTl 1286 is a 9-bit Parity GeneratorA2hecker chip. For Writes to the DRAM array, 
the /PARXMTT signal is driven low, causing the Parity Error lines to be driven high (ie inactive) and 
the PARD lines are driven to the correct parity levels as generated by the 11286 devices. When the / 
PARXMTT signal is high, the PARD lines are used as inputs into the 11286 devices and the stored 
parity is checked against the data on the MD bus. Errors are flagged by one or more of the PERR 
lines being driven low. The individual PERR lines are then combined by U47 to produce a common 
parity error signal PARERR. If an even number of the data lines to a single device are High, the 
associated PARD line should be high; if an odd number of data lines are high, then the PARD line 
should be low. 

The ACT16245 devices also shown on Sheet 3 are the DRAM data buffers. TTiey connect the 
memory data bus to the multiplexed MAD bus. The direction of data flow is controlled by the / 
DBUFDIR signal and the devices are enabled by the /DBUFEN signal. Both of these signals are 
generated by U39 on Sheet 1. When /DBUFDIR is Low, the data flow is from the MAD bus to the 
MD bus. When /DBUFDIR is High, the data flow is from the MD bus to the MAD bus. 
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Sheet 4 MBUS INTERFACE & MISCELLANEOUS HO 


U38 is the MPI ASIC (Mbus to Peripheral Interface Application-Specific Integrated Circuit) that 
forms the interface between the Mbus (MAD0:63) and the on-board PC-AT style buses PA(18:0) and 
PD(1S:0). Several other functional units are integrated into U38, including a programmable intemipt 
encoder (encoding the indiviual intemipt lines /IRQ(9:0) onto the four IRL(3:0) lines that are con¬ 
nected to the 7C6(X) Integer Unit), an address decode (decoding the Mbus address map and providing 
several Chip Select signals - see Chapto' S) and two connections to U28, the 87CS1 programmable 
microcontroller. The MPI ASIC is discussed fully in Chapter 5. 

The MPI ASIC operates by changing Mbus cycles into PC-AT bus cycles. The device includes a 
DMA controller for floppy disk data transfers, and an internal 512byte FIFO to improve efficiency. 
The Mbus cycles can be 8,16,32 or 64bit transfers. The MPI performs byte packing and unpacking 
as required on the 16-bit Pbus, running the necessary number of data cycles on the Pbus until the 
required amount of data has been transferred. The MPI also handles write-posting to the Pbus from 
the Mbus. 

U28 features four 8bit VO ports and is used to control the following facilities: 

Keyboard scanning 

Mouse key interface with host conversion 
Intercepting specific keyboard commands (eg brightness, contrast 
adjustment) 

Monitoring power supply status 

Interfacing to power supply and user system LED indicators 

System temperature measurement 

Reading/writing the system EEPROM 

Adjusting brightness and contrast 

Hardware reset 

U3S, the LTC1()93 from Linear Technology, is a six-channel lObit serial analogue to digital converter. 
A serial command word can be clocked into the device and the A/D conversion result, from the 
channel selected by the command, clocked out and into U28. This provides the mechanism by which 
the system temperature and mouse key are monitored. Four channels are dedicated to the force- 
sensitive resistors that make up the mouse key, enabling the 87CS1 to return a mouse motion value to 
the lU (the 87CS1 calculates the mouse motion using the values returned from the force-sensitive 
resistors and an algorithm programmed into its internal memory). 





U58 and U59 are digitally controlled potentiometers, with a minimum resistance of 40£2, an increment 
size of 505Q and a maximum resistance of S0k£2. US8 controls the display brightness and US9 the 
contrast. The X9C103 from Xicor contains a small area of nonvolatile memory (EEPROM) so that 
settings are not lost when the system is powered off. In response to user commands, the 87C51 can 
increment or decrement the setting of the potentiometer, thereby adjusting the LCD brightness and 
contrast. 

U31, the 380105 device, is a keyboard scanner. At the start of a sequence, U28 asserts then releases 
the Reset line to U31. The 87CS1 then issues a string of CLK pulses to the keyboard scanner, con¬ 
tinuing until the cycle is finished when Reset is driven again. U31 responds by driving DR(1) on the 
flrst clock after Reset, DR(2) on the second, and so on. U31 also monitors the Sense line, SL(x) that 
corresponds to the currently active Drive line, DR(x). If U31 detects a returned signal, it asserts the 
KEYOUT line. The program within U28 keeps track of which Drive lines produce a Sense signal 
within each cycle. If a keyboard character is detected, an interrupt is issued to the lU, causing the lU 
to read the character from a register within U28. 

U32 is a battery-backed 2Kbyte nonvolatile RAM chip, with an integral real time clock. The RTC 
control and time registers overlay the top eight bytes of the memory. U33 is the system EPROM, 
containing the operating firmware for the board. The 8bit data from the EPROM is assembled into 
32-bit instructitms and fixed data for the CPU by the MPI ASIC. 


Sheet 5 PERIPHERAL HO 


U3 is the 82C710 Universal Peripheral Controller, which features a 16450-compatible US ART 
(Universal Serial Asynchronous Receiver/Transmitter), an IDE interface for connection to one or two 
hard disk drives, a nPD72065B-compatible Floppy Disk Controller, a mouse port and a 16-bit PC-AT 
compatible bidirectional parallel port The 82C710 contains a large number of registers and many 
features are software-selectable. To change any of the configuration register values, a complicated 
sequence of write operations has to be undertaken before the changes can be made. This configura¬ 
tion sequence is intentionally kept complicated to minimize the chance of changes being made as a 
result of a programming bug. 

The US ART section of U3 is connected to U45 which converts TTL-level signals to and from RS232 
levels for the serial interface. 



Sheet 6 GRAPHICS 


U46 is the VGA display controller for the monochrome flat panel display, with a sui^lementary CRT 
display capability. The two 256K x4 DRAMs, U16 and U17, form the video memory block, with U16 
containing memory planes 0 and 1, U17 planes 2 and 3. The 64K x4 DRAM, U8, is the Frame 
Accelerator memory, used to buffer the top and bottom half of the display alternately. This procedure 
is used to reduce the display flicker without drastically increasing the current consumption of the 
display controller chip. Note that this device is not required in a color system. 

U23 is a Western Digital WD90C61 frequency synthesizer chip. The internal voltage-controlled 
oscillators and phase-locked loop circuits derive the clock signals OSC and SQCLK from the 
14.312MHz oscillator (XL4) signal The frequency of OSC is controlled by the three CLKSEL lines. 
SQCLK is fixed at 37.585MHz by the settings of the MCLK pins. 

The LT1017 (U34) is a dual comparator/op amp device and is used to pass the LCD contrast and drive 
signals to the LCD. The signals out of U34 can be turned off by the signal PPCTL, which is drived 
from the /DISPOFF signal using TR2 (also on Sheet 6). This circuitry provides a software-controlled 
mechanism for turning off the LCD. The signal BLOFF from TRl turns the LCD backlight off. 


Sheet 7 MODEM AND ETHERNET 


UlS is the Fujitsu 86960 NICE Ethernet Controller, a 16-bit Ethernet controller which uses a 64Kbyte 
block of buffer memcny (U53, U56) for storing receive/transmit data. The CPU accesses the buffer 
memory via the Buffer Memory Port registers within the 86960. Reads from this register retrieve data 
from the receive buffer, writes are directed to the transmit buffer. Read and write points are main¬ 
tained by the 86960 itself, simplifying the operation of loading and retrieving netwoik packets. The 
buffer memory is addressed using the BA(14:0) bus, and data is transferred over the SD(1S:0) bus. 

U22 and US7, together with associated components, make up the Modem interface. U22, the Mottem 
Advanced Controller (MAC), communicates with U57 over the 8bit AD bus and the /SIN, /SOUT 
lines (Serial In, Serial Out). The s^al lines are for transmit and receive data. Hie parallel bus is a 
multiplexed address and data bus and is used for setting up, and passing commands to, US7. U22 
communicates with the lU over the lower 8 bits of the PD bus, with 3 address bits selecting the 
register within the MAC to be accessed by the lU. U22 contains an area of ROM which is pro¬ 
grammed to interact with U57 and provide a 24(X)bps full duplex intelligent modem. The two device 
chip-set performs all the modem functions as well as automatic control features compatible with the 
Hayes “AT” command set. 



Sheets CONNECTORS 


Sheet 8 shows all the connectors present on the SI Base card. 

PHI is the 100-way miniature interboard connector that carries the signal between the base board and 
the CPU module. 

SKI carries the signals between the base board and the internal floppy disk drive unit, SK2 connects 
to the LEDs. 

SK3,4 and 5 make connections with the S1-1/0 board, carrying signals for several of the external 
interfaces. 

SK6 passes the control, timing and data sugnals to the LCD. 

SK7, a S-pin flexible circuit connector, is used to carry signals to the flat panel display backlighting 
system. 

SK8 connects to the force sensitive resistors that make up the mouse key and the On/Off switch. 

SK9, an 8-way connector marked ‘KEYED 1’ on the schematics, is used in conjunction with SKIO, 
an 11-way connector marked ‘KEYED 2’ on the schematics, to make connection with the built-in 
keyboard. SK9 carries the Sense lines, SKIO the Drive lines. 

PLl is used to make the connection to the internal hard disk unit or units. 

(Note the presence of two Chip Select signals, /HDCSO and 1, to allow up to two IDE devices to be 
connected to the cable from PLl.) 

PL2 is used to carry signals and power to and from the power supply unit, with TR3 being used to 
hold the supply ON when the Power On switch is activated. 


Color Systems only - Sheet 9 


On the coltff version of the SPARCbook, the Sl-BASE-C schematics vary slightly from the mono¬ 
chrome version. The changes are confined to some minor changes on Sheets 6 and 8 and the addition 
of a Sheet 9. 

Sheet 8 has extra connectors to carry the signals to the color display. 


146 





Sheet 9 shows the CL-GD6340 color LCD interface controller (U60) which works in conjunction with 
U46 on Sheet 6, plus the color LCD power supply generator circuitry (U63 and associated compo¬ 
nents). 
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Sl-HO SCHEMATIC DESCRIPTION 


The S l-I/O board is used to mount the connectors that interface to the external devices via the 
backpanel of the SPARCbook. Numerous filtering and screening components are present to reduce 
electromagnetic radiation, allowing the SPARCbook to meet FCC standards. 

The circuitry in the lower half of the sheet is used to connect the SCI 1054 modem device (U57, Sheet 
7 of the SI-Base schematics) to the telecommunications network. The signal OH is generated by the 
SCI 1075 Modem Advanced Controller or MAC (U22, Sheet 7 of the Si-Base schematics) and is the 
“off-hook” signal. /MRI is the Ring signal from the same device and when active indicates that the 
modem is receiving a ringing signal. RXTA is the analogue receive/transmit line which is referenced 
to MVREF. 
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Sl-CPV SCHEMATIC DESCRIPTION 


Sheet 1 CY7C601 INTEGER UNIT 


Sheet 1 shows the CY7C601 Integer Unit (or lU, the Central Processor Unit, U2), the CY7C602 
Floating Point Unit (U3), the CY7C604 Cache Controller and Memory Management Unit (Ul, the 
MCT), and two 16Kbyte Cache Storage Units (U4 and U5) - a specialized form of SRAM. All these 
devices are linked by the lU address and data buses, A(31:0) and D(31:0) respectively. Ul provides 
the interface between these buses and the 64-bit multiplexed Mbus, MAD(63:0). It also keeps track of 
the information stored within the cache memory and ctmtrols the cache memory (U4 and US). For 
example, if the Integer Unit carries out a read operation from a main memory location marked as 
cacheable, Ul will cause the data to be written into the cache memory at the same time as it is read by 
U2. If U2 later attempts to carry out another operation to that same address, Ul will divert the cycle 
to the cache instead. If U2 addresses a location that is not held in cache, Ul will translate the proces¬ 
sor bus cycle into an Mbus cycle. Ul will also handle any logical to physical address translation that 
may be required. 

Hie lU is the SPARC processor itself. The two SIZE lines define the size of transf^ currently being 
executed. 8,16,32 and 64-bit operations are identified, with 64-bit operations (Load/Store Double) 
being a special category of data transfer using two 32-bit bus cycles. The ASI lines are the “address 
space identifier” lines, used by multitasking operating systems. MHOLDA is an active LOW signal, 
used to freeze the clock to both the lU and the FPU in the event of a cache miss or an access to slow 
memory via the MCT. DOE is also an active LOW signal and is deasserted to tristate the bus drivers 
on the lU and FPU, allowing the MCT to control the address and data buses. 

The optional FPU (U3) operates concurrently with the lU. The lU identifies floating point instruc¬ 
tions by means of the FINS lines and allows the FPU, when fitted, to pick up instructions and data or 
to supply data. A floating point instructions is concurrently decoded by boA the lU and FPU, but 
does not begin executing in the FPU until after the instruction is enabled by a signal from the lU. 
Several signal lines pass between the FPU and lU to provide the control and handshaking required for 
these operations. 


Sheet 2 100-WAY MINIATURE CONNECTOR 


Sheet 2 shows the 100-way miniature connector that carries the signals between the CPU board and 
the base board. 



CHAPTER THIRTEEN 
SYSTEM COMPONENT SPECIFICATIONS 


LCD COLOR DISPLAY 


Mechanical Characteristics 


Item 

Spaltteattflii 

Unit 


Dimensions 

224(w) xl74(h) xlO.5 max 

mm 

Structure 

640 xR.G.Bx 480(h) 

dot 

Dot size 

0.07 (w)x 0.25(h) 

mm 

Dot pitch 

0.09 (w)x 0.27(h) 

mm 

Effective area 

178 (w)x 134(h) 

mm 


Temperature Range 


Item 


Max 

Unit 


Operating temperature 

10 

40 

“C 

Storage temperature 

-10 

50 

“C 


Ambient temperature (Ta) 

Ta<40“C 

85% Relative Humidity max 

(no dew) 

Ta>40“C 

Below maximum absolute humidity 

of 40“C 85% RH 
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Absolute Maximum Ratings 


Item 

Symbol 

Min 

Max 

Unit 


Power supply for logic 

V -V 

^DD ^SS 

0 

6.0 

V 

Power supply for LC 

Driving 

VsH-Vss 

0 

42 

V 

Input voltage 

V, 

Vss 

Voo 

V 


Electrical Characteristics 

Ta = 25°C, = 5.0V ±5%, =+38V ± IV 


Item 

Symbol 

Condition 

Min 


Max 

Unit 


Input high voltage 



0-8 


V™ 

V 

Input low voltage 

V:. 


Vss 


0-2V^ 

V 

Clock frequency 

feu 


5.38 

5.61 

6.14 

MHz 

Current consumption 

Ido 

= 5.61MHz 



20 

mA 


Ibe 

UD^-'UD, =low 



60 

mA 

LD.~LD, =low 
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Operating voltage for LC driving 


I 

U 


ItSUl Symbol Condition Min IX£ Max IM 


Operating voltage 

Ta=10"C 


38 

V 

J (1/480 duty) V„-V^ 

Ta = 25'C 


(33) 

V 

1 1 

Ta = 40"C 

26 


V 

J Optical Characteristics 


! 1 - 

Item Symbol Condition Min Tvn Max Unit 


Viewing angle 


Ta = 25“C 20 


deg 


Contrast ratio 


Ta = 25“C 


2 







MONOCHROME DISPLAY 


Mechanical Characteristics 


Item SpccmcaHon Ullil 


Dimensions 

255(w) xl72(h) x9.0 max 

mm 

Structure 

640 x 480 (h) 

dot 

Dot size 

0.27 (w)x 0.27(h) 

mm 

Dot pitch 

0.30 (w)x 0.30(h) 

mm 


Temperature Range 


Item 

Min Max linit 



Operating temperature 

10 

40 

“C 

Storage temperature 

-20 

60 

“C 


Ambient temperature (Ta) 

Ta<40"C 


85% Relative Humidity max 

(no dew) 

Ta>40‘’C 


Below maximum absolute humidity 

of 40“C 85% RH 


154 









Absolute Maximum Ratings 


Item 


Min 

Max 

IM 


Power supply for logic 

< 

8 

1 

0 

6.5 

V 

Power supply for LC 

Driving 

V -V 

^DD 

0 

27.5 

V 

Input voltage 

V, 


-0.3 

Vo„-^0.3V 

Input currmt 

I. 


0 

1 A 


Electrical Characteristics 


Item 

Symbol 

Condition 

Min 

Ixn 

Max 

Unit 


Power supply for logic 

V -V 

DD SS 

4.75 

5.0 

5.25 

V 

Power supply for LC 

Vhb-V^ 


-22.0 


V 

Input high voltage 

v„ 

0-8 



V 

Input low voltage 

V.. 

0 



V 

Clock frequency 



(70) 

(85) 

KHz 

Curroit consumption 

Ido 

Vdd-Vss=50V 

(15) 


mA 


Ihe 

V^-V^=-22.0 V 

(11.0) 


mA 






Operating voltage for LC driving 









Item 

Symbol 

CamUlisn 

Min 


Max 

Unit 


Operating voltage 

Ta=10“C 

(23.9) 

V 

o 

> 

f 

§ 

> 

Ta = 25"C 

(23.6) 

V 


Ta = 40“C 

(23.0) 

V 

Optical Characteristics 


Item Symbol Condition MlB Xxfi Ma& linit 


Viewing angle 

Ta = 25'C 

(40) 

deg 

Contrast ratio 

Ta = 25“C 

(5) 

- 
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80MBYTE HARD DISK 


Mechanical Dimensions 



Ambient Relative Humidity 


19.0mm 


70.0mm 

101.6mm 

176g 


Storage Operating 

40“C to 70"C 
20"C/hr gradient 


S-CtoSS^C 
10"C/hr gradient 


5 to 95% non-condensing 


8 to 85% non-condensing 








1 ! 

Power Requirements (at nominal environmental conditions) 

n 

II 

Item 

SDecification 

n 

1 

Voltage 

+5V±5% 


Ripple and Noise 

50mV 


Current: 

rn 

Sleep/Standby 

0.04A 

11 

Parked 

0.16A 


Idle 

0.34A 


Active (R/W) 

0.40A 


Active (Seeking) 

0.44A 


Start up (Peak) 

l.lOA 


Timing Specifications 


Item 


Unit 

I 


Single-Track Seek 

5 

ms 

Average Seek 

19 

ms 

Full Stroke Seek 

30 

ms 

Average Rotational Latency 

8.3 

ms 

Sequential Head Switch 

4 

ms 

Command Overhead 

1 

ms 

Power on to Drive Ready 

<4.0 

s 


Sleep/Standby to Drive Ready 


<2.5 




















Notes: Seek time includes head settling time but not command overhead or rotational-latency 
delays. 

Power On to Drive Ready is the time elq)sed between the supply voltage reaching the operating range and 
the drive being ready to zccepi all commands. 

An ambient temperature of 25 “C, nominal supply voltages and no £q)plied shock or vibration constitute 
nominal conditions. 

Vibration and Shock 


Item Nonoperating QptratinS 


Vibration: 


5 to 300Hz sine wave (peak to peak) 2G IG 

1 ocl/min sine sweep 

Shock: 

1/2 sine wave of 10ms duration lOOG lOG 


(10 hits max; >2 seconds between hits) 
















120MBYTE HARD DISK 




Mechanical Dimensions 




Item 


Units 





Height (max) 

19.1 

mm 



Width (max) 

70.1 

mm 



Depth (max) 

101.9 

mm 



Weight (max) 

185 

8 


1 






Environmental limits 








Storage 


Qptrattng 







Ambient temperature 

-40-C to 70“C 


5*Cto55'C 



30"C/hr gradient 30“C/hr gradient 


Ambient Relative Humidity 8 to 90% non-condensing 8 to 80% non-condensing 

Power Requirements (at nominal environmental conditions) 


Item 


Voltage +5V ±5% 

Current: 


n 


160 

















Sleep/Standby O.lOA 

Idle 0.23A 

Active (R/W) 0.42A 

Active (Seeking) 0.42A 

Start up (Peak) 1 .OOA 


Timing Parameters 


Item Maximnim uii<»er nffmliml ewMiitfons IM 


Single-Track Seek 8 ms 

Average Seek 19 ms 

Full Stroke Seek 30 ms 

Average Rotational Latency 8.7 ms 

Vibration and Shock 


Item Nonoperating Operating 


Vibration: 


22 to 5(X)Hz sine wave (peak to peak) 4G 0.5G 


1 oct/min sine sweep 


Shock: 


1/2 sine wave of 10ms duration lOOG lOG 


(10 hits max; >2 seconds between hits) 
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